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Foreword 



rd , 



This Technical Specification (TS) has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

The present document describes multiplexing, channel coding and interieaving for UTRA Physical Layer TDD mode. 

2 References 

The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 25.202: "UE capabilities". 

[2] 3GPP TS 25.211: "Transport channels and physical channels (FDD)". 

[3] 3GPP TS 25.212: "Multiplexing and channel coding (FDD)". 

[4] 3GPP TS 25.213: "Spreading and modulation (FDD)". 

[5] 3GPP TS 25.214: "Physical layer procedures (FDD)". 

[6] 3GPP TS 25.215: "Physical layer - Measurements (FDD)". 

[7] 3GPP TS 25.221: "Transport channels and physical channels (TDD)". 

[9] 3GPP TS 25.223: "Spreading and modulation (TDD)". 

[10] 3GPP TS 25.224: "Physical layer procedures (TDD)". 

[II] 3GPP TS 25.225: "Measurements". 

[12] 3GPP TS 25.331: "RRC Protocol Specification". 

[13] 3GPP TS 25.308: "High Speed Downlink Packet Access (HSDPA): Overall description (stage 2)". 

3 Definitions, symbols and abbreviations 

3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply. 

TrCH number: transport channel number represents a TrCH ID assigned to LI by L2. Transport channels are 
multiplexed to the CCTrCH in the ascending order of these IDs. 

3.2 Symbols 

For the purposes of the present document, the following symbols apply: 

Ix 1 round towards do, i.e. integer such that x <fx 1 <x+\ 

LxJ round towards -oo, i.e. integer such that x-\ < LxJ <x 
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Ixl 



absolute value of x 



Unless otherwise is explicitly stated when the symbol is used, the meaning of the following symbols are: 

i TrCH number 

j TFC number 

k Bit number 

/ TF number 

m Transport block number 

n Radio frame number 

p PhCH number 

r Code block number 

I Number of TrCHs in a CCTrCH. 

C, Number of code blocks in one TTI of TrCH /. 

F, Number of radio frames in one TTI of TrCH ;. 

M, Number of transport blocks in one TTI of TrCH ;. 

Ntcfi code word Numbcr of TFCI code word bits after TFCI encoding 

P Number of PhCHs used for one CCTrCH. 

PL Puncturing Limit. Signalled from higher layers 

RMi Rate Matching attribute for TrCH /. Signalled from higher layers. 

Temporary variables, i.e. variables used in several (sub)clauses with different meaning. 

x,X 

z,Z 



3.3 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

<ACRONYM> <Explanation> 

ARQ Automatic Repeat on Request 

BCH Broadcast Channel 

BER Bit Error Rate 

BS Base Station 

BSS Base Station Subsystem 

CBR Constant Bit Rate 

CCCH Common Control Channel 

CCTrCH Coded Composite Transport Channel 

CDMA Code Division Multiple Access 

CFN Connection Frame Number 

CQI Channel Quality Indicator 

CRC Cyclic Redundancy Check 

DCA Dynamic Channel Allocation 

DCCH Dedicated Control Channel 

DCH Dedicated Channel 

DL Downlink 

DRX Discontinuous Reception 

DSCH Downlink Shared Channel 

DTX Discontinuous Transmission 

EACH Forward Access Channel 

FDD Frequency Division Duplex 

EDMA Frequency Division Multiple Access 

EEC Forward Error Control 

FER Frame Error Rate 

GF Galois Field 

HARQ Hybrid Automatic Repeat reQuest 

HS-DSCH High Speed Downlink Shared Channel 

HS-PDSCH High Speed Physical Downlink Shared Channel 

HS-SCCH Shared Control Channel for HS-DSCH 

HS-SICH Shared Information Channel for HS-DSCH 
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JD 


Joint Detection 


LI 


Layer 1 


L2 


Layer 2 


LLC 


Logical Link Control 


MA 


Multiple Access 


MAC 


Medium Access Control 


MS 


Mobile Station 


MT 


Mobile Terminated 


NRT 


Non-Real Time 


OVSF 


Orthogonal Variable Spreading Factor 


PC 


Power Control 


PCCC 


Parallel Concatenated Convolutional Code 


PCH 


Paging Channel 


PhCH 


Physical Channel 


PI 


Paging Indicator (value calculated by higher layers) 


Pq 


Paging Indicator (indicator set by physical layer) 


QoS 


Quality of Service 


QPSK 


Quaternary Phase Shift Keying 


RACH 


Random Access Channel 


RF 


Radio Frequency 


RLC 


Radio Link Control 


RMF 


Recommended Modulation Format 


RRC 


Radio Resource Control 


RRM 


Radio Resource Management 


RSC 


Recursive Systematic Convolutional Coder 


RT 


Real Time 


RTBS 


Recommended Transport Block Size 


RU 


Resource Unit 


RV 


Redundancy Version 


SCCC 


Serial Concatenated Convolutional Code 


SCH 


Synchronization Channel 


SNR 


Signal to Noise Ratio 


TCH 


Traffic channel 


TDD 


Time Division Duplex 


TDMA 


Time Division Multiple Access 


TFC 


Transport Format Combination 


TFCI 


Transport Format Combination Indicator 


TFRC 


Transport Format Resouce Combination 


TFRI 


Transport Format Resouce Indicator 


TPC 


Transmit Power Control 


TrBk 


Transport Block 


TrCH 


Transport Channel 


TTI 


Transmission Time Interval 


UE 


User Equipment 


UL 


Uplink 


UMTS 


Universal Mobile Telecommunications System 


USCH 


Uplink Shared Channel 


UTRA 


UMTS Terrestrial Radio Access 


VBR 


Variable Bit Rate 



Multiplexing, channel coding and interleaving 



4.1 



General 



Data stream from/to MAC and higher layers (Transport block / Transport block set) is encoded/decoded to offer 
transport services over the radio transmission link. Channel coding scheme is a combination of error detection, error 
correcting (including rate matching), and interleaving and transport channels mapping onto/splitting from physical 
channels. 
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In the UTRA-TDD mode, the total number of basic physical channels (a certain time slot one spreading code on a 
certain carrier frequency) per frame is given by the maximum number of time slots and the maximum number of 
CDMA codes per time slot. 

4.2 General coding/multiplexing of TrCHs 

This section only applies to the transport channels: DCH, RACH, DSCH, USCH, BCH, FACH and PCH. Other 
transport channels which do not use the general method are described separately below. 

Figure 1 illustrates the overall concept of transport-channel coding and multiplexing. Data arrives to the 
coding/multiplexing unit in form of transport block sets, once every transmission time interval. The transmission time 
interval is transport-channel specific from the set {5 ms**'*, 10 ms, 20 ms, 40 ms, 80 ms}. 

Note: '*" may be appHed for PRACH for 1 .28 Mcps TDD 

The following coding/multiplexing steps can be identified: 

add CRC to each transport block (see subclause 4.2. 1); 

TrBk concatenation / Code block segmentation (see subclause 4.2.2); 

channel coding (see subclause 4.2.3) ; 

radio frame size equalization (see subclause 4.2.4); 

interleaving (two steps, see subclauses 4.2.5 and 4.2.10); 

radio frame segmentation (see subclause 4.2.6); 

rate matching (see subclause 4.2.7); 

multiplexing of transport channels (see subclause 4.2.8); 

bit scrambling (see subclause 4.2.9); 

physical channel segmentation (see subclause 4.2.10); 

sub-frame segmentation(see subclause 4.2.12 only for 1.28Mcps TDD) 

mapping to physical channels (see subclause 4.2.13). 
The coding/multiplexing steps for uplink and downlink are shown in figures 1 and 2. 
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Figure 1 : Transport channel multiplexing structure for uplink and downlink for 3.84Mcps TDD 
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Figure 2: Transport channel multiplexing structure for uplink and downlink of 1.28Mcps TDD 

Primarily, transport channels are multiplexed as described above, i.e. into one data stream mapped on one or several 
physical channels. However, an alternative way of multiplexing services is to use multiple CCTrCHs (Coded Composite 
Transport Channels), which corresponds to having several parallel multiplexing chains as in figures 1 and 2, resulting in 
several data streams, each mapped to one or several physical channels. 
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4.2.1 CRC attachment 

Error detection is provided on transport blocks through a Cyclic Redundancy Check (CRC). The size of the CRC is 24, 
16, 12, 8 or bits and it is signalled from higher layers what CRC size that should be used for each transport channel. 

4.2.1.1 CRC calculation 

The entire transport block is used to calculate the CRC parity bits for each transport block. The parity bits are generated 
by one of the following cyclic generator polynomials: 

gCRC24(£>) = D^' + D^' + D' + D' + D+1 

gCRC16(£>) = £>" + d'' + d'+1 

gcRcniD) = D'' + D" + dV D' + D + 1 

gcRC8(£') = d\d' + d\d' + d+i 

Denote the bits in a transport block delivered to layer 1 by a^^^^ , a -^2 ■• ^im3 ' • • • ' '^imA ' ^'^'^ ^^ parity bits by 
Pimi ' Pim2 ' Pimi ' ■ ■ • ' PimL ■ ^i IS the sizc of a transport block of TrCH /, m is the transport block number, and L, is the 
number of parity bits. L, can take the values 24, 16, 12, 8, or depending on what is signalled from higher layers. 

The encoding is performed in a systematic form, which means that in GF(2), the polynomial: 

DA-+23 , j~.A-+22 , , T~,24 , j-,23 , j-,22 , , nl , 

mil tm2 imAj i iml i un2 i tm23 i tm24 

yields a remainder equal to when divided by gcRC24(£'), polynomial: 

+ a tU +... + a .D +p ,D +p -.D +...+ p- ,.D +p ,^ 

imi tm2 imA^ r imX r im2 r^imlS r^imlo 

yields a remainder equal to when divided by gcRcibiD), polynomial: 

DA +11 , 1-1 A, +10 , , r^l2 , nil , r^lO , , r^l , 

+ a- r,D ' +... + a .D + p. ,D + p. ,L) +...+ p. ,,D + p. ,, 
imi im2 tniAj r iml tim2 r imW r imX2 

yields a remainder equal to when divided by gcRci2(£') and the polynomial: 

a ,D ' + a ^D ' + ... + a- . D + p ,D + p ^D + . . . + p ^D + p g 

iml im2 imAi i unl i tm2 i tml i tmS 

yields a remainder equal to when divided by gcRcs(D). 

If no transport blocks are input to the CRC calculation (M; = 0), no CRC attachment shall be done. If transport blocks 
are input to the CRC calculation (M,5t Q) and the size of a transport block is zero (A,= 0), CRC shall be attached, i.e. all 
parity bits equal to zero. 

4.2.1 .2 Relation between input and output of the CRC attachment block 

The bits after CRC attachment are denoted by bj^^^^ , b-^2 ■• ^im3 ' • • • ' ^imB ' where B, = A, + L,. The relation between ajmk 
and bimk is: 

Kk=aM k=l,2,3,...,A, 

Kk=Pimm+x-(k-A,)) k = Ai+ l,A, + 2,A, + 3, ...,A, + L,. 
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4.2.2 Transport block concatenation and code block segmentation 

All transport blocks in a TTI are serially concatenated. If the number of bits in a TTI is larger than the maximum size of 
a code block, then code block segmentation is performed after the concatenation of the transport blocks. The maximum 
size of the code blocks depends on whether convolutional, turbo coding or no coding is used for the TrCH. 

4.2.2.1 Concatenation of transport blocks 

The bits input to the transport block concatenation are denoted by Z?;^j , bj^2 ■• ^im3 ' • • • ' ^imB where / is the TrCH 
number, m is the transport block number, and B, is the number of bits in each block (including CRC). The number of 
transport blocks on TrCH / is denoted by M,. The bits after concatenation are denoted by Xji,Xj2,Xj^,..., X^^ , where / 
is the TrCH number and Xi=MiBi. They are defined by the following relations: 

^ik = K2,(k-B;) k = Bi+ 1, Bi + 2, ..., 2B, 
% = Kx(k-2B,) k = 2Bi+\, 2B, + 2, ..., 3Bi 



^ik = KM„(k-(M,-i)B,) k = (M, - 1)B, + 1, (Ml - l)B, + 2, ..., M,B,. 

4.2.2.2 Code block segmentation 

Segmentation of the bit sequence from transport block concatenation is performed if X,>Z. The code blocks after 
segmentation are of the same size. The number of code blocks on TrCH / is denoted by C,. If the number of bits input to 
the segmentation, X„ is not a multiple of C„ filler bits are added to the beginning of the first block. If turbo coding is 
selected and X, < 40, filler bits are added to the beginning of the code block. The filler bits are transmitted and they are 
always set to 0. The maximum code block sizes are: 

convolutional coding: Z = 504; 

turbo coding: Z = 5 1 14; 

no channel coding: Z = unlimited. 

The bits output from code block segmentation, for C, i^ 0, are denoted by O^^j , O^^ j ■• 0,^3 , . . . , 0,^^ , where i is the TrCH 
number, r is the code block number, and Ki is the number of bits per code block. 

Number of code blocks: 

\XjZ\ v^hen Z ^ unlimited 
C^=\Q when Z = unlimited and X. = 

1 when Z = unlimited and X. ^ 

Number of bits in each code block (applicable for C, 5^ only): 
if Xi < 40 and Turbo coding is used, then 

K, = 40 
else 

Ki=fXi/Cj 
end if 



£75/ 
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Number of filler bits: F, = C,K, - X, 
for A: = 1 to F,- 



Oiik = 


--0 


end for 




for k=Y, 


+ 1 to Ki 


Onk -- 


' -^iXk-Yi) 


end for 




r = 2 




while r < 


c, 


fork-- 


= 1 to K, 



14 



Insertion of filler bits 
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— Segmentation 



end for 
r = r+l 
end while 

4.2.3 Channel coding 

Code blocks are delivered to the channel coding block. They are denoted by 0-^^,0-^2'^ir3'- ■ ■''-'irK ' where / is the 
TrCH number, r is the code block number, and Kj is the number of bits in each code block. The number of code blocks 
on TrCH / is denoted by C,. After encoding the bits are denoted by y.^^ , y .^2 ■> J,>3 ? • • • ? J,>f ' where F, is the number of 
encoded bits. The relation between Oirk and yi^u and between Ki and F, is dependent on the channel coding scheme. 

The following channel coding schemes can be applied to transport channels: 

convolutional coding; 

turbo coding; 

no coding. 

Usage of coding scheme and coding rate for the different types of TrCH is shown in tables 1 and 2. The values of F, in 
connection with each coding scheme: 

convolutional coding with rate 1/2: F, = 2*Ki + 16; rate 1/3: F, = 3*/r, + 24; 

turbo coding with rate 1/3: F, = 3*^, + 12; 

no coding: Yi = Ki. 

Table 1 : Usage of channel coding scheme and coding rate for 3.84Mcps TDD 



Type of TrCH 


Coding scheme 


Coding rate 


BCH 


Convolutional coding 


1/2 


PCH 


RACH 


DCH, DSCH, FACH, USCH 


1/3, 1/2 


Turbo coding 


1/3 


No coding 
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Table 2: Usage of channel coding scheme and coding rate for 1.28l\/lcps TDD 



Type of TrCH 


Coding scheme 


Coding rate 


BCH 


Convolutional coding 


1/3 


PCH 


1/3, 1/2 


RACH 


1/2 


DCH, DSCH, FACH, USCH 


1/3, 1/2 


Turbo coding 


1/3 


No coding | 



4.2.3.1 Convolutional coding 

Convolutional codes with constraint length 9 and coding rates 1/3 and 1/2 are defined. 

The configuration of the convolutional coder is presented in figure 3. 

Output from the rate 1/3 convolutional coder shall be done in the order output 0, output 1, output 2, output 0, output 1, 
output 2, output 0,..., output 2. Output from the rate 1/2 convolutional coder shall be done in the order output 0, output 
1, output 0, output 1, output 0, ..., output 1. 

8 tail bits with binary value shall be added to the end of the code block before encoding. 

The initial value of the shift register of the coder shall be "all 0" when starting to encode the input bits. 



Input 



D 



►^ 



►e- 



►^ 



-e- 



►e 



-e- 



►e- 



►^ 



-e- 



►e 



Output 
"*'Go = 561 (octal) 

Output 1 

Gi =753 (octal) 



(a) Rate 1/2 convolutional coder 



Input 



►e 



-^ 



►e- 



-^ 



e — ^ 



-^ 



►e- 



►e 



•►e — ^ 



-^ 



►e- 



►e 



Output 
"^Go = 557 (octal) 

Output 1 

Gi =663 (octal) 

rL ^Output 2 

^G2 = 711 (octal) 



(b) Rate 1/3 convolutional coder 
Figure 3: Rate 1/2 and rate 1/3 convolutional coders 



4.2.3.2 



Turbo coding 



4.2.3.2.1 



Turbo coder 



The scheme of Turbo coder is a Parallel Concatenated Convolutional Code (PCCC) with two 8-state constituent 
encoders and one Turbo code internal interleaver. The coding rate of Turbo coder is 1/3. The structure of Turbo coder is 
illustrated in figure 4. 

The transfer function of the 8-state constituent code for PCCC is: 
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G(D)= 






where 



go(D)=l+D^ + D\ 



(D)=l+D + D' 



The initial value of the shift registers of the 8-state constituent encoders shall be all zeros when starting to encode the 
input bits. 

Output from the Turbo coder is , Y'(0), X(l), Y(l), Y'(l), etc: 

Xi, Zi, Z 1, X2, Z2, Z27 ■ ■ -5 ^K7 Zk7 Z A", 

where Xi, X2, ■■■,x^ are the bits input to the Turbo coder i.e. both first 8-state constituent encoder and Turbo code 
internal interleaver, and TTis the number of bits, and z\, Z2, ■■■, Zk and z\, z\, ..., z!k are the bits output from first and 
second 8-state constituent encoders, respectively. 

The bits output from Turbo code internal interleaver are denoted by x'l, x'2, . . ., x'^, and these bits are to be input to the 
second 8-state constituent encoder. 



Xk 



Input 





1st constituent encoder 


Zk 


Xk 


•9 *^ 
^►©-^1 D ^i^►| D hT*^l D 1— 










\ 






Input 

Turbo code 

internal interleaver 

Output 


2nd constituent encoder 


Z'k 


X 


^^ 


-*©-i^| D 1^1 D hr^-l D h- 






1 




X'k 



Output 



/ 



Figure 4: Structure of rate 1/3 Turbo coder (dotted lines apply for trellis termination only) 



4.2.3.2.2 



Trellis termination for Turbo coder 



Trellis termination is performed by taking the tail bits from the shift register feedback after all information bits are 
encoded. Tail bits are padded after the encoding of information bits. 

The first three tail bits shall be used to terminate the first constituent encoder (upper switch of figure 4 in lower 
position) while the second constituent encoder is disabled. The last three tail bits shall be used to terminate the second 
constituent encoder (lower switch of figure 4 in lower position) while the first constituent encoder is disabled. 

The transmitted bits for trellis termination shall then be: 

Xk+\, Zk+\, Xk+2, Zk+2, Xk+3, Zk+3, X k+U Z K+l, X k+1, Z K+2, X K+i, Z K+i- 
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4.2.3.2.3 Turbo code internal interleaver 

The Turbo code internal interleaver consists of bits-input to a rectangular matrix with padding, intra-row and inter-row 
permutations of the rectangular matrix, and bits-output from the rectangular matrix with pruning. The bits input to the 

Turbo code internal interleaver are denoted by ^j , JCj , JC3 , . . . , JC^ , where K is the integer number of the bits and takes 

one value of 40 < K < 51 14. The relation between the bits input to the Turbo code internal interleaver and the bits 

input to the channel coding is defined by Xi^ = 0,yj, and K = Kj. 

The following subclause specific symbols are used in subclauses 4.2.3.2.3.1 to 4.2.3.4.3.3: 

K Number of bits input to Turbo code internal interleaver 

R Number of rows of rectangular matrix 

C Number of columns of rectangular matrix 

p Prime number 

V Primitive root 

(s[jj] . , y. Base sequence for intra-row permutation 

qi Minimum prime integers 

r,- Permuted prime integers 

r(/)V , ■, Inter-row permutation pattern 

U ■ {j)\ Intra-row permutation pattern of i-th row 

i Index of row number of rectangular matrix 

j Index of column number of rectangular matrix 

k Index of bit sequence 

4.2.3.2.3.1 Bits-input to rectangular matrix witin padding 

The bit sequence X^,X2,Xt^,. ..,Xj^ input to the Turbo code internal interleaver is written into the rectangular matrix as 
follows. 

(1) Determine the number of rows of the rectangular matrix, R, such that: 



R 



5,if (40</:<159) 

10, if ((160 <K< 200) or (481 <K< 530)) . 

20, if (K = any other value) 



The rows of rectangular matrix are numbered 0, 1 , ..., R - 1 from top to bottom. 

(2) Determine the prime number to be used in the intra-permutation, p, and the number of columns of rectangular 
matrix, C, such that: 

if (481 < K < 530) then 

p = 53 and C = p. 
else 

Find minimum prime number p from table 3 such that 
K<Rx{p + l), 
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and determine C such that 

p-l if K<Rx(p-l) 
C = \ p if Rx(p-l)<K<Rxp . 

p + l if Rxp <K 

end if 

The columns of rectangular matrix are numbered 0, 1 , 



C - 1 from left to right. 



Table 3: List of prime number p and associated primitive root v 



p 


V 


P 


V 


P 


V 


P 


V 


P 


V 


7 


3 


47 


5 


101 


2 


157 


5 


223 


3 


11 


2 


53 


2 


103 


5 


163 


2 


227 


2 


13 


2 


59 


2 


107 


2 


167 


5 


229 


6 


17 


3 


61 


2 


109 


6 


173 


2 


233 


3 


19 


2 


67 


2 


113 


3 


179 


2 


239 


7 


23 


5 


71 


7 


127 


3 


181 


2 


241 


7 


29 


2 


73 


5 


131 


2 


191 


19 


251 


6 


31 


3 


79 


3 


137 


3 


193 


5 


257 


3 


37 


2 


83 


2 


139 


2 


197 


2 






41 


6 


89 


3 


149 


2 


199 


3 






43 


3 


97 


5 


151 


6 


211 


2 







(3) Write the input bit sequence X^,X2,X2,...,Xj^ into the R XC rectangular matrix row by row starting with bit yi 
in column of row 0: 



Ji yi ys ■■• yc 

y(c+i) y(c+2) y(c+3) ■■■ yic 

yHR-\)C+\) y{{R-\)C+2) 3'((ff-l)C+3) •••3'ffxC 



where ji^ = Xj^ for k= 1,2, . . . , /T and if RXC>K, the dummy bits are padded such that jj^ = Oorl for k = K+ I, 

K+2, ..., RXC. These dummy bits are pruned away from the output of the rectangular matrix after intra-row 
and inter-row permutations. 



4.2.3.2.3.2 



Intra-row and inter-row permutations 



After the bits-input to the RXC rectangular matrix, the intra-row and inter -row permutations for the RXC rectangular 
matrix are performed stepwise by using the following algorithm with steps (1) - (6). 

(1) Select a primitive root v from table 3 in section 4.2.3.2.3.1, which is indicated on the right side of the prime 
number /?. 

(2) Construct the base sequence (s{jj) . , y, for intra-row permutation as: 
s{j)={vxs{j-l))modp, j= 1,2,... (p - 2), and s(0) = 1. 



(3) Assign (70 = 1 to be the first prime integer in the sequence (q 



'7fe{o,i,--,«-i} 



and determine the prime integer qi in 



the sequence (qi). f„ „_.i to be a least prime integer such that g.c.d(^„/7 - 1) = 1, qi > 6, and qi > q^. i) for 
each i= 1,2, ..., R- 1. Here g.c.d. is greatest common divisor. 

(4) Permute the sequence (qi)^ f„. „_.i to make the sequence (rjY , , such that 



rT(i)' 



■qi, i = 0, 1, 



.R- 1, 
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:{0,l,---,«-l} 



is the inter-row permutation pattern defined as the one of the four kind of patterns, 



where (r(/))^^^ 

which are shown in table 4, depending on the number of input bits K. 

Table 4: Inter-row permutation patterns for Turbo code internal interleaver 



Numberof input bits 
K 


Number 
of rows R 


Inter-row permutation patterns 
<7(0), 7(1),..., 7(R-1)> 


(40<K<159) 


5 


<4, 3,2, 1,0> 


(160<K<200)or(481<K<530) 


10 


<9, 8, 7, 6, 5, 4, 3,2, 1,0> 


(2281 < K< 2480) or (31 61 < K< 321 0) 


20 


<19, 9, 14,4,0,2,5,7, 12, 18, 16, 13, 17, 15,3, 1,6, 11,8, 10> 


K= any other value 


20 


<19, 9, 14, 4, 0, 2, 5, 7, 12, 18, 10, 8, 13, 17, 3, 1, 16, 6, 15, 11> 



(5) Perform the /-th (/ = 0,1, ..., R - 1) intra-row permutation as: 
if{C = p) then 

Ui U) = s{{j X r,)mod{p - 1)) , j = 0, 1, . . ., (/^ - 2), and Ui(p - 1) = 0, 

where Ui(j) is the original bit position of y'-th permuted bit of /-th row. 
end if 
if(C=p+ l)then 

Ui U) = s{{j X r,)mod{p - 1)) , j = 0, 1, ..., (p -2). Ui(p - 1) = 0, and Ui(p) = p, 

where Ui(j) is the original bit position of j-th permuted bit of /-th row, and 

if(K=RXQthon 

Exhange Ur.](p) with Ur.](0). 

end if 
end if 
if {C=p- l)then 

Ui{j)=s{{jXr,)mod{p-l))-l, j=0, 1, ..., (p - 2), 

where Ui(j) is the original bit position of j-th permuted bit of /-th row. 
end if 

(6) Perform the inter-row permutation for the rectangular matrix based on the pattern (Tyijj . 



/ie{0,l,--,J?-l}' 

where T{i) is the original row position of the /-th permuted row. 

4.2.3.2.3.3 Bits-output from rectangular matrix with pruning 

After intra-row and inter-row permutations, the bits of the permuted rectangular matrix are denoted by y\: 



y 1 y (R+i) y (2R+1) ■■■y ((c-i)R+i) 
yi y (R+2) y (2R+2) ■■■y ((c-i)r+2) 



y R y2R 



y^R 



y cxR 



The output of the Turbo code internal interleaver is the bit sequence read out column by column from the intra-row and 
inter-row permuted R x C rectangular matrix starting with bit y'l in row of column and ending with bit y'cR in row R 
- 1 of column C - 1 . The output is pruned by deleting dummy bits that were padded to the input of the rectangular 
matrix before intra-row and inter row permutations, i.e. bits jV that corresponds to bits yj^ with k> Kaie removed from 
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the output. The bits output from Turbo code internal interleaver are denoted by x'l, x'2, . . ., x'^, where x'l corresponds to 
the bit y'j. with smallest index k after pruning, x'2 to the bit yV with second smallest index k after pruning, and so on. The 
number of bits output from Turbo code internal interleaver is K and the total number of pruned bits is: 

RXC-K. 

4.2.3.3 Concatenation of encoded blocks 

After the channel coding for each code block, if C, is greater than 1, the encoded blocks are serially concatenated so that 
the block with lowest index r is output first from the channel coding block, otherwise the encoded block is output from 

channel coding block as it is. The bits output are denoted by C, j , C,2 , C,3 , . . . , C,^ , where / is the TrCH number and £, = 
C,F,. The output bits are defined by the following relations: 

Cit=yi,2Xk-Y<) k=Y, + l,Y, + 2,...,2Y, 
Cik=yiMk-2Y,) fe = 27, + 1,27, + 2, ...,37, 



Cit = yi,c„(k-(c,-i)Y,) ^ = (C- - ^^Y. + 1, (C, - 1)7, + 2, ..., C,Yi 
If no code blocks are input to the channel coding (C, = 0), no bits shall be output from the channel coding, i.e. £, = 0. 

4.2.4 Radio frame size equalisation 

Radio frame size equalisation is padding the input bit sequence in order to ensure that the output can be segmented in F, 
data segments of same size as described in the subclause 4.2.6. 

The input bit sequence to the radio frame size equalisation is denoted by C, j , C,2 , (^,3 , . . . , C-^ , where / is TrCH number 

and El the number of bits. The output bit sequence is denoted by t-^ , ?;2 5 ^,3 5 • • • 5 ^,t ' where T; is the number of bits. The 
output bit sequence is derived as follows: 

tik = Cik, for k = 1 . . . £, and 

f„={0,l}fork=£,+l...r„if£,.<r,. 

where 

T, = F,*A?, and 

A' ^- = I EJF^ I is the number of bits per segment after size equalisation. 

4.2.5 1st interleaving 

The 1^' interleaving is a block interleaver with inter-column permutations. The input bit sequence to the block 

interleaver is denoted by .)C, j , .)C, 2 , -f, 3 , • • ■ , ■'C, ^ ' where / is TrCH number and Xj the number of bits. Here Xj is 

guaranteed to be an integer multiple of the number of radio frames in the TTI. The output bit sequence from the block 
interleaver is derived as follows: 

1) select the number of columns CI from table 5 depending on the TTI. The columns are numbered 0, 1, . . ., CI - 1 
from left to right. 

2) determine the number of rows of the matrix, Rl defined as 
Rl =X,/C1. 
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The rows of the matrix are numbered 0, 1, . . ., Rl - 1 from top to bottom. 
3) write the input bit sequence into the Rl X CI matrix row by row starting with bit X- j in column of row and 



ending with bit Xj 



(RlxCl) 



in column CI - 1 of row Rl - 1; 



X. 



X 



;,(Ci+i) 



^/,(Cl+2) 



i,3 



^i,(Cl+3) 



!,C1 



... X, 



i,(2xCl) 



■^i,((Rl-l)xCl+l) ■^/,((Rl-l)xCl+2) •^i,((Rl-l)xCl+3) • • --^/.(RlxCl) 



4) Perform the inter-column permutation for the matrix based on the pattern (Pld \j) 



•-n,\ 1 1/ r 1 shown in table 

5, where PlciO) is the original column position of they-th permuted column. After permutation of the columns, 
the bits are denoted by yit'- 



3^1,1 3'i,(Rl+l) 3'i,(2xRl+l) • • • yi,((Cl-l)xRl+l) 

3^1,2 3'!,(Rl+2) 3'!,(2xRl+2) • • • 3'(,((Cl-l)xRl+2) 



3'i,Ri 3';,(2xRi) 3';,(3xRi) 



yi 



l,(ClxRl) 



5) Read the output bit sequence J, p J, 2 ? J/ 3 ' • • • ? J, (cixRi) °f ^^^ block interleaver column by column from the 
inter-column permuted Rl X CI matrix. Bit y^ j corresponds to row of column and bit y, (rixci) 
corresponds to row Rl - 1 of column CI - 1. 

Table 5 Inter-column permutation patterns for 1st interleaving 



TTI 


Number of columns C1 


Inter-column permutation patterns 
<P1ci(0),P1ci(1),...,P1ci(C1-1)> 


5ms''^', 10 ms 


1 


<0> 


20 ms 


2 


<0,1> 


40 ms 


4 


<0,2,1,3> 


80 ms 


8 


<0,4,2,6,1,5,3,7> 


<^''* r-Qn Ko iicorl fr>r PD 


Ar'H f^r 1 OS \/r^,^c Tnn 





4.2.5.1 



St 



Relation between input and output of 1 interleaving 



The bits input to the 1 ^' interleaving are denoted by tn,tj2^tj^,..., t^ j , where i is the TrCH number and T, the number 
of bits. Hence, Xjj, = tj,, and X, = T,. 

The bits output from the 1 '"' interleaving are denoted by d-^,d^2^d.^T^,...,d-j, and djk = yi,k- 

4.2.6 Radio frame segmentation 

When the transmission time interval is longer than 10 ms, the input bit sequence is segmented and mapped onto 
consecutive F, radio frames. Following radio frame size equalisation the input bit sequence length is guaranteed to be an 
integer multiple of Fj. 

The input bit sequence is denoted by X^^ , X^2 , -^,3 , • • ■ , ■'C,x where / is the TrCH number and X, is the number bits. The Fi 

output bit sequences per TTI are denoted by J, „ 1 5 J, „ 2 ' J; n 3 ' • • • ' Ji nY where n, is the radio frame number in current 
TTI and F, is the number of bits per radio frame for TrCH /. The output sequences are defined as follows: 

yi,n,k = -«,■,((«, -i)J^)+* , «/ = 1 • • -Fi, k=\...Yi 
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where 

Yi = (Xi I Fi) is the number of bits per segment. 
The rij -th segment is mapped to the n, -th radio frame of the transmission time interval. 

The input bit sequence to the radio frame segmentation is denoted by d-^ , d^2 ■• ^n ' • • • ' <^,t ' where / is the TrCH 
number and T, the number of bits. Hence, Xjt = djt and X, = T,. 

The output bit sequence corresponding to radio frame n, is denoted by e^^ , €-2 ,e^^,. . ., e,^ , where / is the TrCH number 
and A^, is the number of bits. Hence, 6- ^ = J, „ ^ and A^, = F,. 

4.2.7 Rate matching 

Rate matching means that bits on a TrCH are repeated or punctured. Higher layers assign a rate-matching attribute for 
each TrCH. This attribute is semi-static and can only be changed through higher layer signalling. The rate-matching 
attribute is used when the number of bits to be repeated or punctured is calculated. 

The number of bits on a TrCH can vary between different transmission time intervals. When the number of bits between 
different transmission time intervals is changed, bits are repeated to ensure that the total bit rate after TrCH 
multiplexing is identical to the total channel bit rate of the allocated physical channels. 

If no bits are input to the rate matching for all TrCHs within a CCTrCH, the rate matching shall output no bits for all 
TrCHs within the CCTrCH. 

Notation used in subclause 4.2.7 and subclauses: 

Nij : Number of bits in a radio frame before rate matching on TrCH / with transport format combination j. 

AA' : If positive - number of bits to be repeated in each radio frame on TrCH / with transport format 

If negative - number of bits to be punctured in each radio frame on TrCH / with transport format 
combination _/. 

RMi : Semi-static rate matching attribute for TrCH /. Signalled from higher layers. 

PL : Puncturing limit. This value limits the amount of puncturing that can be applied in order to minimise the 

number of physical channels. Signalled from higher layers. The allowed puncturing in % is actually equal 
to (1 -PL)* 100. 

Ndata.j '■ Total number of bits that are available for a CCTrCH in a radio frame with transport format 
combination j . 

P : number of physical channels used in the current frame. 

Pmax '■ maximum number of physical channels allocated for a CCTrCH. 

Up : Number of data bits in the physical channel p with p = 1 ...P. 

/ : Number of TrCHs in a CCTrCH. 

Zij : Intermediate calculation variable. 

Fi : Number of radio frames in the transmission time interval of TrCH /. 

n, : Radio frame number in the transmission time interval of TrCH / (0 <ni < F,). 

q : Average puncturing or repetition distance(normalised to only show the remaining rate matching on top of 

an integer number of repetitions). 

Plf(ni) : The column permutation function of the T' interleaver, P1f(x) is the original position of column with 
number x after permutation. PI is defined on table 5 of section 4.2.5 (note that Pip self -inverse). 
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S[n] : The shift of the puncturing or repetition pattern for radio frame Uj when n = P 1 ^ («,. ) . 

TFiij) : Transport format of TrCH i for the transport format combination j . 

TFS(i) ; The set of transport format indexes / for TrCH i. 

ei„i : Initial value of variable e in the rate matching pattern determination algorithm of subclause 4.2.7.3. 

epius : Increment of variable e in the rate matching pattern determination algorithm of subclause 4.2.7.3. 

etninus '■ Decrement of variable e in the rate matching pattern determination algorithm of subclause 4.2.7.3. 

b : Indicates systematic and parity bits. 

b=l: Systematic bit. X(t) in subclause 4.2.3.2.1. 

b=2: V^ parity bit (from the upper Turbo constituent encoder). Y(t) in subclause 4.2.3.2.1. 



4.2.7.1 



b=3: 2" parity bit (from the lower Turbo constituent encoder). Y'(t) in subclause 4.2.3.2.1. 

Determination of rate matching parameters 



The following relations, defined for all TFCy, are used when calculating the rate matching pattern: 



Z.,= 






ilRM„xN„,, ^N,.,., 



ilRM„,xN„j 



for all i= 1 ...7(1) 



AiV,,,=Z,,^-Z,_,,-A^,,^ foralli=l.../ 

Puncturing can be used to minimise the required transmission capacity. The maximum amount of puncturing that can be 
applied is 1-PL, PL is signalled from higher layers. The possible values for Nj^ta depend on the number of physical 
channels P^.^^ , allocated to the respective CCTrCH, and on their characteristics (spreading factor, length of midamble 
and TFCI code word, usage of TPC and multiframe structure), which is given in [7]. 

For each physical channel an individual minimum spreading factor Sp„,i„ is transmitted by means of the higher layers. 
Denote the number of data bits in each physical channel by Up^sp , where /? indicates the sequence number l<p<Pmax 
and Sp indicates the spreading factor with the possible values {76, 8, 4, 2, 1} of this physical channel. The index/? is 
described in section 4.2.13 with the following modifications: spreading factor {Q) is replaced by the minimum 
spreading factor Sp^in and k is replaced by the channelization code index at Q= Sp„,i„. Then, for Njata one of the 
following values in ascending order can be chosen: 



KsU„'f^l,Sl_ +^2,S2„,-t^l,51 ,„ +t^2,S2_ +-+U 



^™x.(SCx)„ 



,1 



Optionally, if indicated by higher layers for the UL the UE shall vary the spreading factor autonomously, so that Njata is 
one of the following values in ascending order: 



Kl6-A,Sl,„-t^l,Sl„„ +t^2,16'-t^l,Sl„„ +t^2,52„--,C/i,Sl„„ +^2.S2„„ +-+ ^^/l^.ie- A,S1„„ +'^2.S2„„ +-+U 



Pm^MPnmX 



.1 



Ndata.j for the transport format combination] is determined by executing the following algorithm: 

SET1 = {N,... such that [minWJjxA^^^,^ -PLX^/?M^XA^^. is non negative 



V 1^>'^^ 



x=l 



Ndata,j=minSETl 
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The number of bits to be repeated or punctured, ANij, within one radio frame for each TrCH i is calculated with the 
relations given at the beginning of this subclause for all possible transport format combinations j and selected every 
radio frame. 

If AA^^y = then the output data of the rate matching is the same as the input data and the rate matching algorithm of 
subclause 4.2.7.3 does not need to be executed. 

Otherwise, the rate matching pattern is calculated with the algorithm described in subclause 4.2.7.3. For this algorithm 
the parameters Cini, epi„s, e^inus, and X, are needed, which are calculated according to the equations in subclauses 4.2.7.1.1 
and 4.2.7.1.2. 

4.2.7.1 .1 Uncoded and convolutionally encoded TrCHs 

a = 2 

AN, = AN,j 

R = ANij mod A^, , — note: in this context ANij mod Nij is in the range of to Ni^-l i.e. -1 mod 10 = 9. 
ifR^0and2xR<A^y 

then q = [A^,,, / r] 
else 

endif 
NOTE 1 : q is a signed quantity. 
If q is even 

then q' = q + gcd( I q I , F,) / F, — where gcd ( I q I , F,) means greatest common divisor of I q I and F, 
NOTE 2: q' is not an integer, but a multiple of 1/8. 
else 

q' = q 
endif 
for X = to F-l 

S [ I Lxxq'j I mod Fi] = ( I Lx*q'J I div F,) 
end for 
e,„, = (a X S[Pl7r,<n,)] x lAA^, 1+1) mod (a x A^^) 

^plus = a X X; 

eminus = a X IAN,I 
puncturing for A/V, <0, repetition otherwise. 

4.2.7.1 .2 Turbo encoded TrCHs 

If repetition is to be performed on turbo encoded TrCHs, i.e. A/V,j>0, the parameters in subclause 4.2.7.1.1 are used. 

If puncturing is to be performed, the parameters below shall be used. Index b is used to indicate systematic (fe=l), l" 
parity (b=2), and 2"'' parity bit (b=3). 
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a = 2 when b=2 
a = 1 when b=3 



AN: 



.^u/^. 
^u/^ 



, b = l 

, b = 3 



If AA^; is calculated as for b=2 or b=3, then the following procedure and the rate matching algorithm of 
subclause 4.2.7.3 don't need to be performed for the corresponding parity bit stream. 

x, = Ln,j/3J, 

q = Lx,/IAN,lJ 
if(q<2) 

for r=0 to F-l 

S[(3xr+b-l) mod F,] = r mod 2; 

end for 
else 

if q is even 

then q' = q - gcd(q, F,)/ Fi — where gcd fq, Fj) means greatest common divisor of q and F, 
NOTE: q' is not an integer, but a multiple of 1/8. 

else q' = q 
endif 
forx=0 to Fi-\ 

r = [xxq'l mod Fc 
S[(3xr+b-l) mod F,] = [xxq'] div F,; 
endfor 
endif 
For each radio frame, the rate-matching pattern is calculated with the algorithm in subclause 4.2.7.3, where: 
Xj is as above, 
e,„i = (axS[Pl Fi (n,)]x-IAA?,l + X,) mod (axX,), if e;„i = then e,,,,- = axX,- 

e minus = axlANil 

4.2.7.2 Bit separation and collection for rate matching 

The systematic bits of turbo encoded TrCHs shall not be punctured, the other bits may be punctured. The systematic 
bits, first parity bits, and second parity bits in the bit sequence input to the rate matching block are therefore separated 
into three sequences. 

The first sequence contains: 

All of the systematic bits that are from turbo encoded TrCHs. 
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From to 2 first and/or second parity bits that are from turbo encoded TrCHs. These bits come into the first 
sequence when the total number of bits in a block after radio frame segmentation is not a multiple of three. 

Some of the systematic, first parity and second parity bits that are for trellis termination. 

The second sequence contains: 

All of the first parity bits that are from turbo encoded TrCHs, except those that go into the first sequence when 
the total number of bits is not a multiple of three. 

Some of the systematic, first parity and second parity bits that are for trellis termination. 

The third sequence contains: 

All of the second parity bits that are from turbo encoded TrCHs, except those that go into the first sequence 
when the total number of bits is not a multiple of three. 

Some of the systematic, first parity and second parity bits that are for trellis termination. 

The second and third sequences shall be of equal length, whereas the first sequence can contain from to 2 more bits. 
Puncturing is applied only to the second and third sequences. 

The bit separation function is transparent for uncoded TrCHs, convolutionally encoded TrCHs, and for turbo encoded 
TrCHs with repetition. The bit separation and bit collection are illustrated in figures 5 and 6. 

Rate matching 



Radio frame 
segmentation 



e* 



^lik 



Bit separation 



^2ik^ 



yuk^ 



Rate matching 
algorithm 



ym^ 



^3ik^ 



Rate matching 
algorithm 



Vs*. 



Bit 

collection 



TrCH 
Multiplexing 



Figure 5: Puncturing of turbo encoded TrCHs 
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Bit 
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Figure 6: Rate matching for uncoded TrCIHs, convolutionally encoded TrCIHs, 
and for turbo encoded TrCIHs with repetition 

The bit separation is dependent on the T' interleaving and offsets are used to define the separation for different TTIs. b 
indicates the three sequences defined in this section, with b=\ indicating the first sequence, b = 2 the second one, and b 
= 3 the third one. 

The offsets at for these sequences are listed in table 6. 

Table 6: TTI dependent offset needed for bit separation 



TTI (ms) 


Ol 


Ob 


OS 


10,40 





1 


2 


20,80 





2 


1 



The bit separation is different for different radio frames in the TTI. A second offset is therefore needed. The radio frame 
number for TrCH / is denoted by n,. and the offset by /5^ . 

Table 7: Radio frame dependent offset needed for bit separation 



TTI (ms) 


Po 


yft 


A 


Ih 


A 


Ik 


Ik 


Ik 


10 





NA 


NA 


NA 


NA 


NA 


NA 


NA 


20 





1 


NA 


NA 


NA 


NA 


NA 


NA 


40 





1 


2 





NA 


NA 


NA 


NA 


80 





1 


2 





1 


2 





1 



4.2.7.2.1 



Bit separation 



The bits input to the rate matching are denoted by e^ ^ , e^ j ? ^, 3 ? • • • ? ^, n ' where / is the TrCH number and A^, is the 
number of bits input to the rate matching block. Note that the transport format combination number j for simplicity has 
been left out in the bit numbering, i.e. Ni=Nij. The bits after separation are denoted by ■'C^ , 1 ' ^fc ; 2 ' ^fe ; 3 ' • • • ' ^/b < x ■ ^'^^ 

turbo encoded TrCHs with puncturing, b indicates the three sequences defined in section 4.2.7.2, with b=\ indicating 
the first sequence, and so forth. For all other cases b is defined to be 1 . X, is the number of bits in each separated bit 
sequence. The relation between e, -^ and X},xk is given below. 



For turbo encoded TrCHs with puncturing: 

^U,k ~ ^i,3(/t-l)+l+(a,+;5„ )mod3 '^ - 1' 2, 3, 



.Xi 



Xi =VNil2>\ 
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^l,i,lN,/3\^-k ~'^i,3lNi/3i+k 



k= 1, ..., Nj mod 3 Note: When (A^, mod 3) = this row is not needed. 



-^2,!,* ~^i,3(i-l)+l+(a2+/S„^)mod3 K - 1, 2, 3, . . ., X/ Xj-iNiBA 

■^3,i,k — ^;,3(*-l)+l+(a3+/S„, )mod3 k = 1, 2, 3, . . ., Xj X; = iNi /3j 

For uncoded TrCHs, convolutionally encoded TrCHs, and turbo encoded TrCHs with repetition: 

k=l,2,3, ...,Xi Xi = Ni 

4.2.7.2.2 Bit collection 

The bits Xb,i,k are input to the rate matching algorithm described in subclause 4.2.7.3. The bits output from the rate 
matching algorithm are denoted y^.^ , y^^.^ ' yh,i,3 ' • • • ' ytjj, ■ 

Bit collection is the inverse function of the separation. The bits after collection are denoted by 

^fc ! 1 ' ^A ! 2 ' ^fo ! 3 ' ■ ■ • ' 2fo ! y ■ After bit collection, the bits indicated as punctured are removed and the bits are then 

denoted by /, p /, 2 ' /; 3 ' • • • ' ft v ' where / is the TrCH number and V, = A^^+AA^y. The relations between yb,i,h Zb,i,h 
and fik are given below. 

For turbo encoded TrCHs with puncturing (F,=X,): 

^i,3('t-l)+l+(ai+/S„,. )mod3 ~ 3'l,i,t '^ ~ 1. 2, 3, ..., Y; 

^i 3\N/3\+k ~ yii\N/3\+k k= I, ..., Ni mod 3 Note: When (A^; mod 3) = this row is not needed. 

^i,3(k-l)+l+(a2+fi„.)mod3 ~ 3^2,/, * '^ - 1' 2, 3, ..., F; 

^i,3(*-l)+l+(a3+/S„,)mod3 ~ 3^3,;,*: '^ - 1' 2, 3, ..., F; 

After the bit collection, bits Zi,k with value S, where <fe{0, 1 }, are removed from the bit sequence. Bit/J i corresponds to 
the bit Zi,k with smallest index k after puncturing, bit/J;2 corresponds to the bit Zi,k with second smallest index k after 
puncturing, and so on. 

For uncoded TrCHs, convolutionally encoded TrCHs, and turbo encoded TrCHs with repetition: 

Zi,k = yu,k fe=i,2,3,...,y, 

When repetition is ViS,&d,fik=Zi,k and y,=y,. 

When puncturing is used, Yj=Xi and bits Zi,k with value S, where (fe{0, 1 }, are removed from the bit sequence. Bit/j_i 
corresponds to the bit z^k with smallest index k after puncturing, bit/j- 2 corresponds to the bit Zi,k with second smallest 
index k after puncturing, and so on. 

4.2.7.3 Rate matching pattern determination 

The bits input to the rate matching are denoted by X^-^,X^2^^i3^- ■ -^^i x^ ^ where / is the TrCH and X^ is the parameter 
given in subclauses 4.2.7. 1 . 1 and 4.2.7.1.2. 

NOTE: The transport format combination number j for simplicity has been left out in the bit numbering. 

The rate matching rule is as follows: 

if puncturing is to be performed 
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e = ^ini — initial error between current and desired puncturing ratio 
m = 1 — index of current bit 

do while m <= X, 

e = e- e„,„„j -- update error 

if e <= then — check if bit number m should be punctured 

set bit x,„, to (J where (fe{0, 1 } 
e = e + CpUts — update error 

end if 

m = m + 1 — next bit 

end do 
else 

e = ei„j — initial error between current and desired puncturing ratio 
m = 1 — index of current bit 

do while m <= X, 

e = e- e„,„„, -- update error 

do while e <= — check if bit number m should be repeated 

repeat bit x, ,„ 

e = e + Cpius — update error 
end do 

m = m + 1 — next bit 

end do 
end if 
A repeated bit is placed directly after the original one. 

4.2.8 TrCH multiplexing 

Every 10 ms, one radio frame from each TrCH is delivered to the TrCH multiplexing. These radio frames are serially 
multiplexed into a coded composite transport channel (CCTrCH). If the TTI is smaller than 10ms, then no TrCH 
multiplexing is performed. 

The bits input to the TrCH multiplexing are denoted by /^ j , /^ 2 , /, 3 , • • • , /, y. ' where / is the TrCH id number and V, 
is the number of bits in the radio frame of TrCH /. The number of TrCHs is denoted by /. The bits output from TrCH 
multiplexing are denoted by h^,h2,hT,,...,hg , where S is the number of bits, i.e. S = /^V^ • The TrCH multiplexing is 

defined by the following relations: 

hk=f2,(k-vo k=V, + l,V,+2,...,V,+V2 

h = /3,(*-(v,+v,)) k = fvi+yzj+i, fVi+y2J+2, .... (Vi+V2)+V3 
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h = //,(Mv,w,+...w,_,)) k = (Vi+V2+...+V,.0+l (V,+V2+...+V,.i)+2, ..., (Vi+V2+...+V,.i)+V, 

4.2.9 Bit Scrambling 

The bits output from the TrCH multiplexer are scrambled in the bit scrambler. The bits input to the bit scrambler are 
denoted by /ij , /z2 , /z3 , . . . , /z^ , where S is the number of bits input to the bit scrambling block equal to the total number of 

bits on the CCTrCH. The bits after bit scrambling are denoted ^j , ^j , 53 , . . . , 5^ . 
Bit scrambling is defined by the following relation: 

Sk=h®Pk k=l,2...,S 
and Pi^ results from the following operation: 

f 16 \ 

Pk= T. S. ■ Pk-. mod 2 ; p, = 0; /c < 1 ; p, = 1 ; g= {0,0,0,0,0,0,0,0,0,0,l,0,l,l,0,l} 

V i=i J 

4.2.10 PInysical cinannel segmentation 

When more than one PhCH is used, physical channel segmentation divides the bits among the different PhCHs. The bits 
input to the physical channel segmentation are denoted by i'j , ^j , 53 , . . . , 5^ , where S is the number of bits input to the 
physical channel segmentation block. The number of PhCHs is denoted by P. 

The bits after physical channel segmentation are denoted U ^,U 2^^ n3^---^^ pu ' where p is PhCH number and Up is 

the in general variable number of bits in the respective radio frame for each PhCH. The relation between St and Up_k is 
given below. 

Bits on first PhCH after physical channel segmentation: 

Wu=** k=l,2,...,Uj 
Bits on second PhCH after physical channel segmentation: 

Hk=S(k^u,) k=l,2,...,U2 



Bits on the P* PhCH after physical channel segmentation: 

^p,k - ^(k+Ui+...+Up_,) k= 1,2 ,..., Up 

4.2.11 2nd interleaving 

The 2""^ interleaving is a block interleaver and consists of bits input to a matrix with padding, the inter-column 
permutation for the matrix and bits output from the matrix with pruning. The 2nd interleaving can be applied jointly to 
all data bits transmitted during one frame, or separately within each timeslot, on which the CCTrCH is mapped. The 
selection of the 2nd interleaving scheme is controlled by higher layer. 



4.2.1 1 .1 Frame related 2nd interleaving 



ind ■ 



In case of frame related 2 interleaving, the bits input to the block interleaver are denoted by Xi,X2,X^,...,X^ , where 
U is the total number of bits after TrCH multiplexing transmitted during the respective radio frame with 



p 
p 
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The relation between Xk and the bits Up^k in the respective physical channels is given below: 

X^ = Mj^ k= 1,2 , ...,Ui 



^(k^u,)=U2,k k=l,2,...,U2 



^(k+Ui + ...+Up_i)~^P,k ^-1^2, ..., f/p 



The following steps have to be performed once for each CCTrCH: 

(1) Assign C2 = 30 to be the number of columns of the matrix. The columns of the matrix are numbered 0, 1,2, 
C2 - 1 from left to right. 

(2) Determine the number of rows of the matrix, R2, by finding minimum integer R2 such that: 
f/ < R2 X C2. 

The rows of rectangular matrix are numbered 0, 1,2, ..., R2 - 1 from top to bottom. 

(3) Write the input bit sequence X^,X2,X^,...,Xjj into the R2 X C2 matrix row by row starting with bit y^ in 
column of row 0: 



3^1 

3^(02+1) 



3'((R2- 



l)xC2+l) 



y 



3^(02+2) 
((R2-l)xC2+2) 



y 



3^3 

3^(C2+3) 

((R2-l)xC2+3) 



3^02 
3'(2xC2) 



3'(R2: 



;xC2) 



where J^ = X^. for k= 1,2, . . ., U and if R2 x C2 > U, the dummy bits are padded such that y^. = or 1 for k = 

U + 1, U +2, . . ., R2 X C2. These dummy bits are pruned away from the output of the matrix after the inter- 
column permutation. 

(4) Perform the inter-column permutation for the matrix based on the pattern <P 2yj)j . , , that is shown in 

table 8, where P2(/) is the original column position of they'-th permuted column. After permutation of the 
columns, the bits are denoted by y\ . 



y 1 3^ (R2+1) 3^ (2XR2+1) ••■y ((C2-l)xR2+l) 

3^ 2 3^ (R2+2) 3^ (2XR2+2) • • • 3^ ((C2-l)xR2+2) 



3^ R2 3^ (2xR2) 3^ (3xR2) 



3^ (C2xR2) 



(5) The output of the block interleaver is the bit sequence read out column by column from the inter-column 
permuted R2 X C2 matrix. The output is pruned by deleting dummy bits that were padded to the input of the 

matrix before the inter-column permutation, i.e. bits y' f, that corresponds to bits yf, with A: > L'^ are removed 

from the output. The bits after frame related 2"'' interleaving are denoted by Vj , Vj , . . . , V^ , where Vi corresponds 

to the bit y\ with smallest index k after pruning, V2 to the bit y\ with second smallest index k after pruning, 
and so on. 
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4.2.1 1 .2 Timeslot related 2"^ interleaving 

In case of timeslot related 2"** interleaving, the bits input to the block interleaver are denoted by ;c, j , .x:, 2 ? -f , 3 , • • • , -f , y , 

where t refers to a certain timeslot, and U, is the number of bits transmitted in this timeslot during the respective radio 
frame. 

In each timeslot t the relation between Xt^k and Ut^p^k is given below with P, refering to the number of physical channels 
within the respective timeslot: 



■'^t,(k+U,^ + ■■■+U,^p^_^)) ^i,P,,k 



k=l,2, ..., U„ 



The following steps have to be performed for each timeslot t, on which the respective CCTrCH is mapped: 

(1) Assign C2 = 30 to be the number of columns of the matrix. The columns of the matrix are numbered 0, 1,2, ..., 
C2 - 1 from left to right. 

(2) Determine the number of rows of the matrix, R2, by finding minimum integer R2 such that: 
U,<R2x C2. 

The rows of rectangular matrix are numbered 0, 1,2, ..., R2 - 1 from top to bottom. 

(3) Write the input bit sequence X^ ^,Xj 2'^t 3'---'-^t u ^'^'■° ^^^ ^^ ^ ^^ matrix row by row starting with bit y^ j 
in column of row 0: 



yt,(C2+\) 



yr,2 
yt,(C2+2) 



y,,3 

3'f,(C2+3) 



yi,C2 
yt,(2xC2) 



3'r,((R2-l)xC2+l) 3'(,((R2-l)xC2+2) 3'r,((R2-l)xC2+3) • • • 3'(,(R2xC2) 



where y, j; = X^ f, for k= 1,2, ..., U, and if R2 x C2 > U„ the dummy bits are padded such that y^ f, = or 1 for 

k= U,+ 1, U, + 2, . . ., R2 X C2. These dummy bits are pruned away from the output of the matrix after the inter- 
column permutation. 

(4) Perform the inter-column permutation for the matrix based on the pattern (P 2(7)) . , , that is shown in 

table 8, where P2(/) is the original column position of they-th permuted column. After permutation of the 
columns, the bits are denoted by y\ j^ ■ 



y t,\ y /,(R2+1) 3^ /,(2xR2+l) ■■■y r,((C2-l)xR2+l) 
3^ t,2 y (,(R2+2) 3^ r,(2xR2+2) • • • 3^ f,((C2-l)xR2+2) 



3^ /,R2 3^ ;,(2xR2) 3^ r,(3xR2) 



3^ f,(C2xR2) 



(5) The output of the block interleaver is the bit sequence read out column by column from the inter-column 
permuted R2 X C2 matrix. The output is pruned by deleting dummy bits that were padded to the input of the 

matrix before the inter-column permutation, i.e. bits y\ ^ that corresponds to bits y, f. with k> U, are removed 
from the output. The bits after time slot 2"'^ interleaving are denoted by V, j , V, 2 ? • • • ? ^; £/ ' where Vt, 1 
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corresponds to the bit y\ ^ with smallest index k after pruning, Vt,2 to the bit y\ f, with second smallest index k 
after pruning, and so on. 

Table 8 Inter-column permutation pattern for 2nd interleaving 



Number of Columns C2 


Inter-column permutation pattern 
< P2(0), P2(1), ..., P2(C2-1)> 


30 


<0, 20, 10, 5, 15, 25, 3, 13, 23, 8, 18, 28, 1, 11, 21, 
6, 16, 26, 4, 14, 24, 19, 9, 29, 12, 2, 7, 22, 27, 17> 



4.2.1 2 Sub-frame segmentation for the 1 .28 Mcps option 

In the 1.28Mcps TDD, it is needed to add a sub-frame segmentation unit between 2nd interleaving unit and physical 
channel mapping unit. The operation of rate-matching guarantees that the bit streams is a even number and can be 
subdivided into 2 sub-frames. The transport channel multiplexing structure for uplink and downlink is shown in figure 

2. 

The input bit sequence is denoted by 'i ' '2 ' /3 ' ' (X, ^jjgj-g j jg ^jjg XrCH number and X; is the number bits. The 

two output bit sequences per radio frame are denoted by '•"''' ''"'^' ''"'■'' ' ''"'^ where ni is the sub-frame 
number in current radio frame and Yi is the number of bits per radio frame for TrCH i. The output sequences are defined 
as follows: 

y',n,k ^ ^i,{{n,-i}YM ^n,= 1 or2,k= 1...Y, 
where 
Yi = (Xi / 2) is the number of bits per sub-frame, 

'* is the k* bit of the input bit sequence and 

i,n;k jg jjjg j^th i^jj. ^^ j.j^g output bit sequence corresponding to the n* sub-frame 

The input bit sequence to the sub-frame segmentation is denoted by *" , Xi^ = V(t)k and Xi = U(t). 

The output bit sequence corresponding to subframe n; is denoted by '' '' '' '' , where p is the PhCH number 

and Up is the number of bits in one subframe for the respective PhCH. Hence, '' '"' and Up = Yj. 

4.2.13 Pinysical cinannel mapping 

4.2.1 3.1 Physical channel mapping for the 3.84 Mcps option 

The PhCH for both uplink and downlink is defined in [6]. The bits after physical channel mapping are denoted by 

W J , W 2 5 • • ■ 5 "Wp u ' where p is the PhCH number corresponding to the sequence number l<p<P„,ax of this physical 

channel as detailed below, and Up is the number of bits in one radio frame for the respective PhCH. The bits W^yt are 
mapped to the PhCHs so that the bits for each PhCH are transmitted over the air in ascending order with respect to k. 

The physical channel sequence number/? are to be allocated by the physical layer in ascending order of the timeslots in 
which they appear. If more than one physical channel appears in a timeslot, they shall be allocated the sequence number 
in order of the timeslot first and then of their channelisation codes. The channelisation codes shall be ordered in 
ascending order of the spreading factor {Q) and then channelisation code index (fe), as shown in [9]. 

The mapping of the bits V,j-.^,V,j-. 2,...,V(,)y is performed like block interleaving, writing the bits into columns, but a 
PhCH with an odd number is filled in forward order, were as a PhCH with an even number is filled in reverse order. 
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The mapping scheme, as described in the following subclause, shall be applied individually for each timeslot t used in 
the current frame. Therefore, the bits V, j , V, 2 v? V, ^ are assigned to the bits of the physical channels 

^M,i...c/„ '>^/,2,i...[/„ '■■■''^,,p„i...u„^ in each timeslot. 

In uplink there are at most two codes allocated (P<2). If there is only one code, the same mapping as for downlink is 
applied. Denote SFl and SF2 the spreading factors used for code 1 and 2, respectively. For the number of consecutive 
bits to assign per code bs^ the following rule is applied: 

if 

SFl >= SF2 then bs, = 1 ; bs2 = SF1/SF2 ; 
else 

SF2 > SFl then bsi = SF2/SF1; bsz = 1 ; 
end if 
In the downlink case bSp is 1 for all physical channels. 

4.2.13.1.1 Mapping scheme 

Notation used in this subclause: 

P ,: number of physical channels for timeslot t , P,= 1 ..2 for uplink , P,= 1 ... 16 for downlink 
U,y. capacity in bits for the physical channel p in timeslot t 
U,: total number of bits to be assigned for timeslot t 
bSp: number of consecutive bits to assign per code 
for downlink all bSp = 1 

for uplink if SFl >= SF2 then bsi = 1 ; bs2 = SF1/SF2 ; 
ifSF2>SFl thenbsi = SF2/SFl;bs2= 1 ; 
fbp: number of already written bits for each code 
pos: intermediate calculation variable 
for p=l to f , — reset number of already written bits for every physical channel 

fbp = 
end for 

p = 1 -- start with PhCH #1 

fork=l to U,, 

do while (fbp == U,^p) — physical channel filled up already ? 

p = (p mod PO + 1 ; 
end do 
if (p mod 2) == 

pos = U,^p - fbp — reverse order 

else 

pos = fbp + 1 — forward order 
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endif 

>Vt,p,pos = Vt,k -- assignment 

fbp = fbp + 1 — Increment number of already written bits 

if (fbp mod bSp) == — Conditional change to the next physical channel 

p = (p mod Pl) + 1 ; 
end if 
end for 

4.2.1 3.2 Physical channel mapping for the 1 .28 Mcps option 

The bit streams from the sub-frame segmentation unit are mapped onto code channels of time slots in sub-frames. 

The bits after physical channel mapping are denoted by ' , where p is the PhCH number and Up is 

the number of bits in one sub-frame for the respective PhCH. The bits wpk are mapped to the PhCHs so that the bits for 
each PhCH are transmitted over the air in ascending order with respect to k. 

Q Q ... J? 

The mapping of the bits '' '' '' ' is performed like block interleaving, writing the bits into columns, but a 

PhCH with an odd number is filled in forward order, were as a PhCH with an even number is filled in reverse order. 

The mapping scheme, as described in the following subclause, shall be applied individually for each timeslot t used in 

Q Q Q 

the current subframe. Therefore, the bits f f p p ^re assigned to the bits of the physical channels 

in each timeslot. 



'^/I,l...(/„''^(2,l...(/,2'--'^;P,,l...t/,p, 



In uplink there are at most two codes allocated (P<2). If there is only one code, the same mapping as for downlink is 
applied. Denote SFl and SF2 the spreading factors used for code 1 and 2, respectively. For the number of consecutive 
bits to assign per code bsk the following rule is applied: 

if 

SFl >= SF2 then bs, = 1 ; bs2 = SF1/SF2 ; 

else 

SF2 > SFl then bsi = SF2/SF1; bsz = 1 ; 

end if 

In the downlink case bSp is 1 for all physical channels. 

4.2.13.2.1 Mapping scheme 

Notation used in this subclause: 

P t: number of physical channels for timeslot t , P, = 1..2 for uplink ; Pt = 1...16 for downlink 
Utp: capacity in bits for the physical channel p in timeslot t 
Ut.: total number of bits to be assigned for timeslot t 
bSp: number of consecutive bits to assign per code 
for downlink all bSp = 1 

for uplink if SFl >= SF2 then bs, = 1 ; bs2 = SF1/SF2 ; 
if SF2 > SFl then bsj = SF2/SF1; bsj = 1 ; 
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fbp! number of already written bits for each code 

pos: intermediate calculation variable 

for p=l to P , — reset number of already written bits for every physical channel 

fbp = 

end for 

p = 1 - start with PhCH #1 

fork=l toUf 

do while (fbp == Ut,p) — physical channel filled up already ? 

p = (p mod Ft) + 1 ; 

end do 

if (p mod 2) == 

pos = Ut,p - fbp — reverse order 

else 

pos = fbp + 1 — forward order 

end if 

Wtp.pos = gt,k -- assignment 

fbp = fbp + 1 — Increment number of already written bits 

If (fbp mod bSp) == — Conditional change to the next physical channel 

p = (p mod P t) + 1 ; 

end if 

end for 

4.2.1 4 Multiplexing of different transport channels onto one CCTrCH, and 
mapping of one CCTrCH onto physical channels 

Different transport channels can be encoded and multiplexed together into one Coded Composite Transport Channel 
(CCTrCH). The following rules shall apply to the different transport channels which are part of the same CCTrCH: 

1) Transport channels multiplexed into one CCTrCh shall have co-ordinated timings. When the TFCS of a 

CCTrCH is changed because one or more transport channels are added to the CCTrCH or reconfigured within 
the CCTrCH, or removed from the CCTrCH, the change may only be made at the start of a radio frame with 
CFN fulfilhng the relation 



where F^ax denotes the maximum number of radio frames within the transmission time intervals of all transport 
channels which are multiplexed into the same CCTrCH, including any transport channels ; which are added 
reconfigured or have been removed, and CFN denotes the connection frame number of the first radio frame of the 
changed CCTrCH. 

After addition or reconfiguration of a transport channel i within a CCTrCH, the TTI of transport channel ; may only 
start in radio frames with CFN fulfilling the relation 

CFN; mod F, = 0. 

2) Different CCTrCHs cannot be mapped onto the same physical channel. 
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3) One CCTrCH shall be mapped onto one or several physical channels. 

4) Dedicated Transport channels and common transport channels cannot be multiplexed into the same CCTrCH. 

5) For the common transport channels, only the FACH and PCH may belong to the same CCTrCH. 

6) Each CCTrCH carrying a BCH shall carry only one BCH and shall not carry any other Transport Channel. 

7) Each CCTrCH carrying a RACH shall carry only one RACH and shall not carry any other Transport Channel. 
Hence, there are two types of CCTrCH. 

CCTrCH of dedicated type, corresponding to the result of coding and multiplexing of one or several DCH. 

CCTrCH of common type, corresponding to the result of the coding and multiplexing of a common channel, i.e. RACH 
and USCH in the upUnk and DSCH, BCH, FACH or PCH in the downlink, respectively. 

Transmission of TFCI is possible for CCTrCH containing Transport Channels of: 

dedicated type; 

- USCH type; 

- DSCH type; 

- FACH and/or PCH type. 

4.2.1 4.1 Allowed CCTrCH combinations for one UE 

4.2.14.1.1 Allowed CCTrCH combinations on the uplink 

The following CCTrCH combinations for one UE are allowed, also simultaneously: 

1) several CCTrCH of dedicated type; 

2) several CCTrCH of common type. 

4.2.14.1.2 Allowed CCTrCH combinations on the downlink 

The following CCTrCH combinations for one UE are allowed, also simultaneously: 

3) several CCTrCH of dedicated type; 

4) several CCTrCH of common type. 

4.2.15 Transport format detection 

Transport format detection can be performed both with and without Transport Format Combination Indicator (TFCI). If 
a TFCI is transmitted, the receiver detects the transport format combination from the TFCI. When no TFCI is 
transmitted, so called blind transport format detection may be used, i.e. the receiver side uses the possible transport 
format combinations as a priori information. 

4.2.1 5.1 Blind transport format detection 

Blind Transport Format Detection is optional both in the UE and the UTRAN. Therefore, for all CCTrCH a TFCI shall 
be transmitted, including the possibility of a TFCI code word length zero, if only one TEC is defined. 
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4.2.1 5.2 Explicit transport format detection based on TFCI 



4.2.15.2.1 



Transport Format Combination Indicator (TFCI) 



The Transport Format Combination Indicator (TFCI) informs the receiver of the transport format combination of the 
CCTrCHs. As soon as the TFCI is detected, the transport format combination, and hence the individual transport 
channels' transport formats are known, and decoding of the transport channels can be performed. 

4.3 Coding for layer 1 control for the 3.84 Mcps option 
4.3.1 Coding of transport format combination indicator (TFCI) 

Encoding of the TFCI depends on its length. If there are 6-10 bits of TFCI the channel encoding is done as described in 
subclause 4.3.1.1. Also specific coding of less than 6 bits is possible as explained in subclause 4.3.1.2. 



4.3.1.1 



Coding of long TFCI lengths 



The TFCI is encoded using a (32, 10) sub-code of the second order Reed-MuUer code. The coding procedure is as 
shown in figure 7. 



TFCI (10 bits) 
a9...ao 



(32,10) sub-code Of 
the second order 
Reed-Muller code 



TFCI code word 



Figure 7: Channel coding of the TFCI bits 

TFCI is encoded by the (32, 1 0) sub-code of second order Reed-Muller code. The code words of the (32, 1 0) sub-code of 
second order Reed-Muller code are linear combination of some among 10 basis sequences. The basis sequences are as 
follows in table 9. 
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Table 9: Basis sequences for (32,10) TFCI code 
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The TFCI bits ao , ai , a2 , 33 , 34 , as , ag , ay , ag , ag (where ao is LSB and a^ is MSB) shall correspond to the TFC index 
(expressed in unsigned binary form) defined by the RRC layer to reference the TFC of the CCTrCH in the associated 
DPCH radio frame. 

The output TFCI code word bits bj are given by: 

9 



Z7, = E(a„xM,,„)mod2 



«=o 



where / = 0, . . .,3 1 . Ntfci c 



32. 



4.3.1.2 



Coding of short TFCI lengths 



4.3.1.2.1 



Coding very short TFCIs by repetition 



If the number of TFCI bits is 1 or 2, then repetition will be used for coding. In this case each bit is repeated to a total of 
4 times giving 4-bit transmission (Ntfci code word =4) for a single TFCI bit and 8-bit transmission (Nxfci code word =8) for 2 
TFCI bits. The TFCI bit(s) bo (or bo and bi where bo is the LSB) shall correspond to the TFC index (expressed in 
unsigned binary form) defined by the RRC layer to reference the TFC of the CCTrCH in the associated DPCH radio 
frame. In the case of two TFCI bits denoted bo and b| the TFCI code word shall be { bo, bi bo, bi bo.bi bo b| }. 



4.3.1.2.2 



Coding short TFCIs using bi-orthogonal codes 



If the number of TFCI bits is in the range 3 to 5 the TFCI is encoded using a (16, 5) bi-orthogonal (or first order Reed- 
MuUer) code. The coding procedure is as shown in figure 8. 
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TFCI (5 bits) 
a4...ao 




TFCI code word 

bn...b|. 



Figure 8: Channel coding of short length TFCI bits 

The code words of the (16,5) bi-orthogonal code are hnear combinations of 5 basis sequences as defined in table 10. 

Table 10: Basis sequences for (16,5) TFCI code 
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The TFCI bits ao , ai , a2 , aj , a4 (where ao is LSB and a4 is MSB) shall correspond to the TFC index (expressed in 
unsigned binary form) defined by the RRC layer to reference the TFC of the CCTrCH in the associated DPCH radio 
frame. 

The output code word bits bj are given by: 



Z?, = E(a„xM,,„)mod2 



n=0 



where / = 0, . . . , 1 5 . Ntfci code ^ 



16. 



4.3.1 .3 Mapping of TFCI code word 

The mapping of the TFCI code word to the TFCI bit positions in a timeslot shall be as follows. 

Denote the number of bits in the TFCI code word by Ntfci code word, denote the TFCI code word bits by b^ where k=0. 

Ntfci code word - 1 ■ 



bo 


■ ■ ■ 


bN/2-1 


bN/2 


■ ■ ■ 


bN-i 




/ 






\ 





first part of TFCI code word 



second part of TFCI code word 



Figure 9: Mapping of TFCI code word bits to timeslot 

The locations of the first and second parts of the TFCI code word in the timeslot is defined in [7]. 
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If the shortest transmission time interval of any constituent TrCH is at least 20 ms the successive TFCI code words in 
the frames in the TTI shall be identical. If TFCI is transmitted on multiple timeslots in a frame each timeslot shall have 
the same TFCI code word. 

4.3.2 Coding and Bit Scrambling of tine Paging Indicator 

The paging indicator Pq, ^ = 0, ..., A^pi-l, P, e {0, 1 } is an identifier to instruct the UE whether there is a paging 
message for the groups of mobiles that are associated to the PI, calculated by higher layers, and the associated paging 
indicator Pq. The length Lpi of the paging indicator is Lpi=2, Lpi=4 or Lpi=8 symbols. A'pjb = 2*A'pi*Lpi bits are used for 
the paging indicator transmission in one radio frame. The mapping of the paging indicators to the bits e„ ;' = 1, ..., A'pib is 
shown in table 1 1 . 

Table 11 : Mapping of the paging indicator 



Pp 


Bits {e2Lpi*q+1, 62Lpi*q+2, ■.■ ,62Lpi*(q+1) } 


Meaning 





{0,0, ...,0} 


There is no necessity to receive the PCH 


1 


{1,1,..., 1} 


There is the necessity to receive the PCH 



If the number S of bits in one radio frame available for the PICH is bigger than the number A'pib of bits used for the 
transmission of paging indicators, the sequence e = [ei, ej, ..., eNPm} is extended by S-Npm bits that are set to zero, 
resulting in a sequence h = {hi, h2, ..., hg): 

^k ~ ^k' k — i^, ..., J^ piB 

The bits h^ , k= I, ..., S on the PICH then undergo bit scrambling as defined in section 4.2.9. 

The bits s^, k= 1, ...,S output from the bit scrambler are then transmitted over the air as shown in [7]. 



4.4 Coding for layer 1 control for the 1 .28 Mcps option 

4.4.1 Coding of transport format combination indicator (TFCI) for QPSK 

The coding of TFCI for 1.28Mcps TDD is same as that of 3.84Mcps TDD. cf. [4.3.1 'Coding of transport format 
combination indicator']. 



4.4.1.1 



Mapping of TFCI code word 



Denote the number of bits in the TFCI code word by Ntfci code word, and denote the TFCI code word bits by b^, where k : 
0, . . . , Ntfci code word - 1 

When the number of bits in the TFCI code word is 8, 16, 32, the mapping of the TFCI code word to the TFCI bit 
positions shall be as follows: 
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'^0 '^N/4-1 '-'n/4 '^N/2-1 '^N/2 '^3N/4- 1 '^3N/4 '^N- 1 



1 St part of 
TFCI code word 



2nd part of 
TFCI code word 



3rd part of 
TFCI code word 





4th part of 
TFCI code word 



Figure 10: Mapping of TFCI code word bits to TFCI position in 1.28 Mcps TDD option, 

where N = NtfcI code word- 
When the number of bits of the TFCI code word is 4 , then the TFCI code word is equally divided into two parts for the 
consecutive two subframe and mapped onto the end of the first data field in each of the consecutive subframes.The 
mapping for Ntfci code word =4 is shown in figure 1 1 : 



bO,bl 



b2,b3 




Figure 1 1 : Mapping of TFCI code word bits to TFCI position in 1 .28 Mcps TDD option, 

when Ntfci code word.=4 

The location of the 1st to 4th parts of the TFCI code word in the timeslot is defined in [7]. 

If the shortest transmission time interval of any constituent TrCH is at least 20 ms, then successive TFCI code words in 
the frames within the TTI shall be identical. If a TFCI is transmitted on multiple timeslots in a frame each timeslot shall 
have the same TFCI code word. 

4.4.2 Coding of transport format combination indicator (TFCI) for 8PSK 

Encoding of TFCI bits depends on the number of them and the modulation in use. When 2 Mcps service is transmitted, 
8PSK modulation is applied in 1 .28 Mcps TDD option. The encoding scheme for TFCI when the number of bits are 6 - 
10, and less than 6 bits is described in section 4.4.2.1 and 4.4.2.2, respectively. 



4.4.2.1 



Coding of long TFCI lengths 



When the number of TFCI bits is 6 - 10, the TFCI bits are encoded by using a (64,10) sub-code of the second order 
Reed-Muller code, then 16 bits out of 64 bits are punctured (Puncturing positions are 0, 4, 8, 13, 16, 20, 27, 31, 34, 38, 
41, 44, 50, 54, 57, 61^' bits). The coding procedure is shown in Figure 12. 
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TFCI 
(10 bits) 



(64,10) sub-code 
of second order 
Reed Muller code 



Puncturing 



TFCI code word 
'^Q .... b47 



Figure 12: Channel coding of long TFCI bits for 8PSK 

The code words of the punctured (48,10) sub-code of the second order Reed-MuUer codes are Hnear combination of 10 
basis sequences. The basis sequences are shown in Table 12. 
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Table 12: Basis sequences for (48,10) TFCI code 
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Let's define the TFCI bits as ao , ai , a2 , as , 34 , as , ag , a? , ag , ag, where ao is the LSB and ag is the MSB. The TFCI bits 
shall correspond to the TFC index (expressed in unsigned binary form) defined by the RRC layer to reference the TFC 
of the CCTrCH in the associated DPCH radio frame. 

The output TFCI code word bits bi are given by: 
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Z7, = E(a„xM,,„)mod2 



where i=0...47. Ntfcic 



1=48. 



4.4.2.2 



Coding of short TFCI lengths 



4.4.2.2.1 



Coding very short TFCIs by repetition 



When the number of TFCI bits is 1 or 2, then repetition will be used for the coding. In this case, each bit is repeated to a 
total of 6 times giving 6-bit transmission (Ntfci code word = 6) for a single TFCI bit and 12-bit transmission (Nxfci code word 
= 12) for 2 TFCI bits. For a single TFCI bit bo, the TFCI code word shall be {bo, bo, bo, bo, bo, bo). For two TFCI bits bg 
and bi, the TFCI code word shall be {bo, bi, bo, bi, bo, bi, bo, bi, bo, bi, bo, bi}. 



4.4.2.2.2 



Coding short TFCIs using bi-orthogonal codes 



If the number of TFCI bits is in the range of 3 to 5, the TFCI bits are encoded using a (32,5) first order Reed-Muller 
code, then 8 bits out of 32 bits are punctured (Puncturing positions are 0, 1,2, 3, 4, 5, 6, 7* bits). The coding procedure 
is shown in Figure 13. 



TFCI 
(5 bits) 



(32,5) First order 
Reed-Muller code 



Puncturing 



TFCI code word 



•^q ..., b 



23 



Figure 13: Channel coding of short TFCI bits for 8PSK 

The code words of the punctured (32,5) first order Reed-Muller codes are linear combination of 5 basis sequences 
shown in Table 13. 



£75/ 



3GPP TS 25.222 version 5.0.0 Release 5 



46 



ETSI TS 125 222 V5.0.0 (2002-03) 



Table 13: Basis sequences for (24,5) TFCI code 
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Let's define the TFCI bits as ao , ai , a2 , as , a4, where ao is the LSB and a4 is the MSB. The TFCI bits shall correspond 
to the TFC index (expressed in unsigned binary form) defined by the RRC layer to reference the TFC of the CCTrCH in 
the associated DPCH radio frame. 

The output code word bits h, are given by: 

^, = i(a„xM,,„)mod2 

n=0 



where i=0 . . . 23 . Ntfci code ^ 



=24. 



4.4.2.3 



Mapping of TFCI code word 



Denote the number of bits in the TFCI code word by Ntfci code word^ and denote the TFCI code word bits by bj^, where k = 

0, . . . , NxFCI code word " 1 ■ 

When the number of bits in the TFCI code word is 12, 24 or 48, the mapping of the TFCI code word to the TFCI bit 
positions in a time slot shall be as follows. 




'-'n/4-1 '-'n/4 



'^N/2-1 '-'n/2 



'-'3N/4-1 '-'3N/4 



'N-1 



1 St part of 
TFCI code word 




2nd part of 
TFCI code word 




3rd part of 
TFCI code word 




4th part of 
TFCI code word 



Figure 14: Mapping of TFCI code word bits to timeslot in 1.28 Mcps TDD option, 

where N = Ntfci code word- 
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When the number of bits in the TFCI code word is 6, the TFCI code word is equally divided into two parts for the 
consecutive two sub-frames and mapped onto the first data field in each of the consecutive sub-frames. The mapping of 
the TFCI code word to the TFCI bit positions in a time slot shall be as shown in figure 15. 



bo, bi, b2 



bs, b4, bs 



1 St part of 
TFCI code word 




2nd part of 
TFCI code word 



3rd part of 
TFCI code word 




4th part of 
TFCI code word 



Figure 15: Mapping of TFCI code word bits to timeslot in 1.28 Mcps TDD option when Ntfci code word = 6 

The location of the 1st to 4th parts of the TFCI code word in the timeslot is defined in [7]. 

4.4.3 Coding and Bit Scrambling of tine Paging Indicator 

The paging indicator Pq, ^ = 0, ..., A^pi-l, P^ e {0, 1 } is an identifier to instruct the UE whether there is a paging 
message for the groups of mobiles that are associated to the PI, calculated by higher layers, and the associated paging 
indicator Pq. The length Lpi of the paging indicator is Lpi=2, Lpi=4 or Lpi=8 symbols. A^pib = 2*A^pi*Lpi bits are used for 
the paging indicator transmission in one radio frame. The mapping of the paging indicators to the bits e„ / = 1, ..., A^pib is 
shown in table 14. 

Table 14: Mapping of the paging indicator 



Pq 


Bits {e2Lp|*q+1, e2Lp|*q+2, ... ,e2Lp|*(q+1) } 


Meaning 





{0, 0, ..., 0} 


There is no necessity to receive the PCH 


1 


{1,1,..., 1} 


There is the necessity to receive the PCH 



If the number S of bits in one radio frame available for the PICH is bigger than the number A^pjb of bits used for the 
transmission of paging indicators, the sequence e = [ei, ej, ..., eNPm} is extended by 5-A^pib bits that are set to zero, 
resulting in a sequence h = {hi, h2, ..., hs): 

h=ek, k = l,...,NpjB 
h,=0, k = Npis,...,S 

The bits hf, , k= I, ..., S on the PICH then undergo bit scrambling as defined in section 4.2.9. 

The bits s^, k= I, ..., S output from the bit scrambler are then transmitted over the air as shown in [7]. 

4.4.4 Coding of the Fast Physical Access Channel (FPACH) information 
bits 

The FPACH burst is composed by 32 information bits which are block coded and convolutional coded, and then 
delivered in one sub-frame as follows: 

1. The 32 information bits are protected by 8 parity bits for error detection as described in sub-clause 4.2.1.1. 

2. Convolutional code with constraint length 9 and coding rate Vi is applied as described in sub-clause 4.2.3.1. 
The size of data block c(k) after convolutional encoder is 96 bits. 

3. To adjust the size of the data block c(k) to the size of the FPACH burst, 8 bits are punctured as described in sub- 
clause 4.2.7 with the following clarifications: 
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Nj.j =96 is the number of bits in a radio sub-frame before rate matching 

AN, y = -8 is the number of bits to punctured in a radio sub-frame 

- e,n, = a X Ny 

The 88 bits after rate matching are then deUvered to the intra-frame interleaving. 

4. The bits in input to the interleaving unit are denoted as {x(0), ..., x(87)}. The coded bits are block rectangular 
interleaved according to the following rule: the input is written row by row, the output is read column by 
column. 



x(0) x(l) x(2) 
x(S) x(9) .x;(10) 



47)' 
415) 

.:c(87) 



480) 481) 482) .. 

Hence, the interleaved sequence is denoted by y (i) and are given by: 
y(0), y(l), ..., y(87)=x(0), x(8), ...,x(80),x(l), ..., x(87). 



4.5 Coding for HS-DSCH 



Figure 16 illustrates the overall concept of transport-channel coding and multiplexing for HS-DSCH. Data arrives to the 
coding/multiplexing unit in form of one transport block once every transmission time interval. The transmission time 
interval is 5 ms for 1.28Mcps TDD and 10ms for 3.84 Mcps TDD. 

The following coding/multiplexing steps for HS-DSCH can be identified: 

add CRC to each transmission time interval (see subclause 4.5.1); 

code block segmentation (see subclause 4.5.2); 

channel coding (see subclause 4.5.3); 

hybrid ARQ (see subclause 4.5.4); 

bit scrambling (see subclause 4.5.5); 

physical channel segmentation (see subclause 4.5.6); 

interleaving for HS-DSCH (see subclauses 4.5.7); 

mapping to physical channels (see subclause 4.5.8); 

constellation re-arrangement for 16QAM (see subclause 4.5.9). 
The coding steps for HS-DSCH are shown in figure 16. 
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Figure 16. Transport channel multiplexing structure for HS-DSCH 

In the following the number of transport blocks is always one. When referencing non HS-DSCH formulae which are 
used in correspondence with HS-DSCH formulae the convention is used that transport block subscripts may be omitted 
(e.g. Xi when i is always 1 may be written X). 

4.5.1 CRC attachment for HS-DSCH 

A CRC of size 24 bits is calculated and added per HS-DSCH TTI. The CRC polynomial is defined in 4.2.1.1 with the 
following specific parameters: i=l, Li = 24 bits. 
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4.5.2 Code block segmentation for HS-DSCH 

Code block segmentation for the HS-DSCH transport channel shall be done with the general method described in 
4.2.2.2 above with the following specific parameters. 

There will only be one transport block, i=l. The bits bin,i, bin,2, bin,3,...bin,B input to the block are mapped to the bits Xji, 
Xi2, Xi3,...Xixi directly. It follows that Xi = B. Note that the bits x referenced here refer only to the internals of the code 
block segmentation function. 

The value of Z = 5 1 14 for turbo coding shall be used. 

4.5.3 Channel coding for HS-DSCH 

Channel coding for the HS-DSCH transport channel shall be done with the general method described in 4.2.3.2 above 
with the following specific parameters. 

There will be a maximum of one transport block, i=l. The rate 1/3 turbo coding shall be used. 

4.5.4 Hybrid ARQ for HS-DSCH 

The hybrid ARQ functionality matches the number of bits at the output of the channel coder to the total number of bits 
of the HS-PDSCH set to which the HS-DSCH is mapped. The hybrid ARQ functionality is controlled by the 
redundancy version (RV) parameters. The exact set of bits at the output of the hybrid ARQ functionality depends on the 
number of input bits, the number of output bits, and the RV parameters. 

The hybrid ARQ functionality consists of two rate-matching stages and a buffer as shown in the figure below. 

The first rate matching stage matches the number of input bits to the virtual IR buffer, information about which is 
provided by higher layers. Note that, if the number of input bits does not exceed the virtual IR buffering capability, the 
first rate-matching stage is transparent. 

The second rate matching stage matches the number of bits after first rate matching stage to the number of physical 
channel bits available in the HS-PDSCH set in the TTI. 
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Figure 17: HS-DSCH hybrid ARQ functionality 



4.5.4.1 



HARQ bit separation 



The HARQ bit separation function shall be performed in the same way as bit separation for turbo encoded TrCHs in 

4.2.7.2 above. 
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4.5.4.2 HARQ First Rate Matching Stage 

HARQ first stage rate matching for the HS-DSCH transport channel shall be done with the general method described in 
4.2.7.1.2 above with the following specific parameters. 

The maximum number of soft bits available in the virtual IR buffer is Nir which is signalled from higher layers for each 
HARQ process. The number of coded bits in a TTI before rate matching is N^^' this is deduced from information 
signalled from higher layers and parameters signalled on the HS-SCCH for each TTI. Note that HARQ processing and 
physical layer storage occurs independently for each HARQ process currently active. 

If Nir is greater than or equal to N^^' (i.e. all coded bits of the corresponding TTI can be stored) the first rate matching 
stage shall be transparent. This can, for example, be achieved by setting e„„„„.5 = 0. Note that no repetition is performed. 

If Nir is smaller than N^^' the parity bit streams are punctured as in 4.2.7.1.2 above by setting the rate matching 

parameter AA^., = A^^^ — A^ where the subscripts i and 1 refer to transport channel and transport format in the 

referenced sub-clause. Note the negative value is expected when the rate matching implements puncturing. Bits selected 
for puncturing which appear as 5 in the algorithm in 4.2.7 above shall be discarded and not counted in the totals for the 
streams through the virtual IR buffer. 

4.5.4.3 HARQ Second Rate Matching Stage 

HARQ second stage rate matching for the HS-DSCH transport channel shall be done with the general method described 
in 4.2.7.3 above with the following specific parameters. 

The parameters of the second rate matching stage depend on the value of the RV parameters s and r. The parameter s 
can take the value or 1 to distinguish self-decodable (s = 1) and non self-decodable (s = 0) transmissions. The 
parameter r (range to r„a^) changes the initial error variable e,„, in the case of puncturing. In case of repetition both 
parameters r and s change the initial error variable «;„;. The parameters X, Cpius and e,ninus are calculated as per table 15 
below. 

Denote the number of bits before second rate matching as A^,^, for the systematic bits, Npj for the parity 1 bits, and Np2 
for the parity 2 bits, respectively. Denote the number of physical channels used for the CCTrCH by P. Njam is the 
number of bits available to the CCTrCH in one radio frame and defined as Ndaia=P^^'>^datau where N^iatai is defined in 
[2]. The rate matching parameters are determined as follows. 

For N j^j^ < N n-s "*" ^ p\ "*" -^ p2 ' puncturing is performed in the second rate matching stage. The number of 
transmitted systematic bits in a retransmission is A'^, ^^.^ = min|A'^j^,j , N ^^,^ j for a transmission of self-decodable type 
and N^ ^y,. = maxJA^^^,^ - [N ^^ + N ^^ \^\ i" *^ "°" self-decodable case. 



For N j^j^ > N + N ^ + N 2 repetition is performed in the second rate matching stage. A similar repetition rate in 
all bit streams is achieved by setting the number of transmitted systematic bits to A^^ 



N 

\T data 

N,,+2N 



svs 



sys p2 



The number of parity bits in a transmission is; A^, j = 



parity 1 and parity 2 bits, respectively. 



A^ -A^ 

data t,sys 



and N,^p2 = 



N -N 

data t,sys 



for the 



Table 15 below summarizes the resulting parameter choice for the second rate matching stage. The parameter a in the 
table is chosen using a = 2 for parity 1 and a = 1 for parity 2. 
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Table 15: Parameters for HARQ second rate matching 





Xi 


Splus 


Gmlnus 


Systematic 
RMS 


A^,v. 


N.,. 




A^,v.-A^,,... 




Parity 1 
RM P1_2 


^.1 


a-N,„ 


a ■ 


^.i-^.,.i 




Parity 2 
RM P2_2 


Nr2 


^■Np2 


a- 


N,2-N,,, 





^.2- 



The rate matching parameter e,„; is calculated for each bit stream according to the RV parameters r and s using 

^ini [r] = {[X, - (r ■ e^,„, / r^^^ ) - 1] mod e^,„,} + 1 in the case of puncturing , i.e., N,^,^ < A^,^,, + A^^i + N ^„ 
and 

(^ini{r) = {[x, -((5 + 2T)-e^,„/(2-r_))-l]mode^,J + lforrepetition,i.e., N,^,^ > A^,,, + A^,, + 

Where r G |0, 1, • • • , r^^^ — 1 j and r^^^ is the total number of redundancy versions allowed by varying r . Note that 
Tmax varies depending on the modulation mode. 

Note: For the modulo operation the following clarification is used: the value of (x mod y) is strictly in the range of to 
y-1 (i.e. -1 mod 10 = 9). 

4.5.4.4 HARQ bit collection 

The HARQ bit collection is achieved using a rectangular interleaver of size A^^ow ^ ^coi ■ 
The number of rows and columns are determined from: 

A^™. = log,(M) 

where M is the modulation size and F is the number of coded and rate-matched bits to be transmitted. 
Data is written into the interleaver column by column, and read out of the interleaver column by column. 
Nt,sys is the number of transmitted systematic bits. Intermediate values A^,. and A^^ are calculated using: 



A^. 



A^ 



t,sys 



N 



col 



and A^„ 



A^, 



kN.., 



■-N. 



■N. 



lfNc=0, the systematic bits are written into rows 1 . . .A^,.. 

Otherwise systematic bits are written into rows 1 . . .Nr+1 in the first Nc columns and rows 1 . . .A^^ in the remaining A^^ 
columns. The remaining space is filled with parity bits. The parity bits are written column wise into the remaining rows 
of the respective columns. Parity 1 and 2 bits are written in alternating order. 

In the case of 16QAM for each column the bits are read out of the interleaver in the order row 1, row 3, row 2, row 4. In 
the case of QPSK for each column the bits are read out of the interleaver in the order rowl, row2. 

4.5.5 Bit scrambling 

The bit scrambling for HS-DSCH shall be done with the general method described in subclause 4.2.9. 
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4.5.6 Physical channel segmentation for HS-DSCH 

When more than one HS-PDSCH is used, physical channel segmentation divides the bits among the different physical 
channels. The bits input to the physical channel segmentation are denoted by W|, W2, Wj,. . .Wr, where R is the number of 
bits input to the physical channel segmentation block. The number of PhCHs is denoted by P. 

The bits after physical channel segmentation are denoted U ^,U 2^U ^^, . . . ,U jj , where/? is PhCH number and L'^is the 

number of bits in one TTI for each HS-PDSCH, i.e. P. The relation between Wyt and Upk is given below. 

For all modes, some bits of the input flow are mapped to each code until the number of bits on the code is U. 
Bits on first PhCH after physical channel segmentation: 

ui,k= Wk k = 1,2, ..., U 
Bits on second PhCH after physical channel segmentation: 

U2.k= Wk+u k= 1,2, ...,U 



Bits on the P' PhCH after physical channel segmentation: 

Up, k = w't+fp-iixf/ k = 1,2, . . ., U 

4.5.7 Interleaving for HS-DSCH 

The interleaving for TDD is done as shown in figure 18 below, separately for each physical channel. The bits input to 

the block interleaver are denoted by U^,U2,U^,...,Ujj , where L'^is the number of bits in one TTI. For QPSK the 

interleaver is the same as Rel99 2"'' interleaver described in Section 4.2. 11.1. The interleaver is of fixed size: R2=32 
rows and C2=30 columns. 



u, (QPSK) 



u^,.! (16QAM) 



U2^{16QAM) 



R'99 

Interleaver 

(32x 30) 



R'99 

Interleaver 

(32x 30) 



V, (QPSK) 



V,,., (16QAM) 



v„^(16QAM) 



Figure 18: Interleaver structure for HSDPA 

For 16QAM, there are two identical interleavers of the same fixed size R2XC2 = 32X30. The output bits from the 
physical channel segmentation are divided between the interleavers: all odd numbered bits to interleaver one and all 
even numbered bits to interleaver two. 

Note: the outputs of the interleavers will result in mapping to 16QAM symbols such that the output of first interleaver is 
mapped to the more reliable positions (/i and ^i) whereas the output of the second interleaver is mapped to the less 
reliable positions ((2 and qi). 

4.5.8 Physical channel mapping for HS-DSCH 

The HS-PDSCH is defined in [7] . The bits input to the physical channel mapping are denoted by V j , V j ? • • • ? V^ , 

where /? is the physical channel number and L'^is the number of bits in one TTI for one HS-PDSCH. The bits Vpk are 
mapped to the PhCHs so that the bits for each PhCH are transmitted over the air in ascending order with respect to k. 
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4.5.9 Constellation re-arrangement for 1 6 QAM 

This function only applies to 16 QAM modulated bits. In case of QPSK it is transparent. 

The following table 16 describes the operations that produce the different rearrangements. 

The bits of the input sequence are mapped in groups of 4 so that Vp^, Vp^+i, Vpk+i, Vpk+3 map to iJi^q-dlb, where k mod 4 : 
0. 

Table 16: Constellation re-arrangement for 16 QAM 



Constellation 

version 
parameter b 


Output bit 
sequence 


Operation 





L^Jh^h 


None 


1 


ihWala 


Swapping 4 with k and q^ with q^ 


2 


iaiJhIh 


XOR with 001 1 (equivalent to inversion of the logical values of k and Qb) 


3 


ihWala 


Swapping 4 with k and Qa with Qband XOR with 001 1 



The output bit sequences from the table above map to the output bits in groups of 4, i.e. rpi;, rpj^+i, rpj;+2, r^^+i, where k 
mod 4 = 0. 

4.6 Coding/Multiplexing for HS-SCCH 

The following information, provided by higher layers, is transmitted by means of the HS-SCCH physical channel. 
Channelisation-code-set information (8 bits): x^cs.b ^ccs.i' •■•> ^ccs.s 
Time slot information (nbits where n = 5 for 1.28 Mcps TDD and n = 13 for 3.84 Mcps TDD): 

Modulation scheme information (1 bit): x„.,j 

Transport-block size information (m bits where m = 6 for 1.28 Mcps TDD and m = 9 for 3.84 Mcps TDD): 

Hybrid-ARQ process information (3 bits): Xij^pj, x^^pj, Xij^pj 

Redundancy version information (3 bits): Xn.j, Xrv,2,Xrv.3 

New data indicator (1 bit): x„jj 
- UE identity (10 bits): x„^,y, x„e,2, ■■•, x,„jo 
The following coding/multiplexing steps can be identified: 

multiplexing of HS-SCCH information (see subclause 4.6.1) 

CRC attachment (see subclause 4.6.2); 

channel coding (see subclause 4.6.3); 

rate matching (see subclause 4.6.4); 

interleaving for HS-SCCH (see subclause 4.6.5); 

mapping to physical channels (see subclause 4.6.6). 
The general coding/multiplexing flow is shown in the figure below. 
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4.6.1 Multiplexing of HS-SCCH information 

The information carried on the HS-SCCH is multiplexed onto the bits a^ , flj , . • •'^l^ according to the following rule 



a^ , fljQ . . ■Clg+„_i -f,, J , -f ,j_2 • • •■"•&,« 



^9+« ^ms,l 



^10+n+m ' ^1 1+n+m ' ^12+n+m -^hap,! ' ^hap,2 ' ^hap,3 



^13+n+m ' ^\A+n+m ' ^l5+n+m ^rv,\ ' ^rv,2 ' ^rv,i 



4.6.2 CRC attachment for HS-SCCH 

The bits bi, ..., be are generated by adding the computed CRC of length 16 as described in the general section 4.2.1.1, 
and then scrambling the computed CRC by the modulo 2 addition of an extended UE identifier. The MSBs of the UE 
identifier shall be extended to 16 bits by zero padding. 
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4.6.3 Channel coding for HS-SCCH 

Channel coding for the HS-SCCH shall be done with the general method described in 4.2.3 with the following specific 
parameters: 

The rate 1/3 convolutional coding shall be used for HS-SCCH. 

4.6.4 Rate matching for HS-SCCH 

Rate matching for HS-SCCH shall be done with the general method described in 4.2.7. 

4.6.5 Physical Channel Segmentation for HS-SCCH 

Physical Channel Segmentation for HS-SCCH shall be done with the general method described in 4.2.10. For 1.28 
Mcps TDD, the HS-SCCH consists of two physical channels HS-SCCHl and HS-SCCH2; for 3.84 Mcps TDD the HS- 
SCCH only uses one physical channel, see [7]. 

4.6.6 Interleaving for HS-SCCH 

Interleaving for HS-SCCH shall be done with the general method described in 4.2.11.1. 

4.6.7 Physical channel mapping for HS-SCCH 

Physical channel mapping for the HS-SCCH shall be done with the general method described in subclause 4.2.13. 

4.7 Coding for HS-SICH 

The following information, provided by higher layers, is transmitted by means of the HS-SICH physical channel. 
Recommended Modulation Format (RMF) (1 bit): Xrmfj 
Recommended Transport -block size (RTBS) (n bits where n = 6 for 1.28 Mcps TDD and n = 9 for 3.84 Mcps 

IDD): X,i,sJ, X,i,s,2, ■■■, X,i,s,n 

- Hybrid- ARQ information ACK/NACK (1 bit): Xan.i 
The following coding/multiplexing steps can be identified: 

- separate coding of RMF, RTBS and ACK/NACK (see subclause 4.7.1); 

- multiplexing of HS-SICH information (4.7.2); 
interleaving for HS-SICH (see subclause 4.7.3); 
mapping to physical channels (see subclause 4.7.4). 

The general coding/multiplexing flow is shown in the figure 19. 
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Figure 19 Coding and multiplexing for HS-SICH 

4.7.1 Coding for HS-SICH 

4.7.1 .1 Field Coding of ACK/NACK 

The ACK/NACK field of the HS-SICH is repetition coded to 36 bits. The coded bits are defined as Cj . . .Cjg 

4.7.1.2 Field Coding of CQI 

4.7.1 .2.1 Field Coding of CQI for 1 .28 Mcps TDD 

The quaUty information consists of Recommended Transport Block Size (RTBS) and Recommended Modulation 
Format (RMF) fields. The 6 bits of the RTBS field are coded to 32 bits using a (32, 6) T' order Reed-Muller code. The 
coding procedure is as shown in figure 20. 



TBSS (6 bits) 
a ...a 



(32,6) sub-code of 
the first order 
Reed-Muller code 



TBSS code word 
b ...b 



Figure 20 Field coding of RTBS information bits 

The coding uses a subset basis sequences as the TFCI coder as described in subclause 4.3.1.1. The basis sequences that 
are used for RTBS coding are as follows in table 17. 
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Table 17: Basis sequences for (32,6) RTBS code 
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The output RTBS code word bits b; are given by: 

where / = 0, . . .,3 1 . Nrtbs code word = 32. 

The 1 bit of the RMF is repetition coded to 1 6 bits to produce the bits . ZJjj , ^33 . . -b^j . 

The CQI is composed of the bits Zi,Z2---Z„ where: 

ZvZ2-z„^^, =b,,b^...b„ 

4.7.1 .2.2 Field Coding of CQI for 3.84 Mcps TDD 

RTBS and RMF bits are multiplexed onto the bits y^, J2-")'io according to the following rule : 

3^2' 3'3-"3'lO ~ ■^tbs,l'^tbs,2'"-'^tbs,9 
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The bits y^, )^2"-)'io^re coded to produce the CQI bits Zi,Z2---Z„ using a (32,10) sub-code of the second order 
Reed-Muller code as defined in subclause 4.3.1.1, where n^„ = 32 . 

4.7.2 Multiplexing of HS-SICH information fields 

The CQI bits Zi,Z2---Z„ are multiplexed with the repetition coded ACK/NACK bits Cj.-.Cjg to produce the bits 
d^,d2---dy where U is the number of physical channel bits carried by HS-SICH, according to the following rule.: 

d^,d2...d„ =ZiZ2--Z„ 
' ^ "cQi '■ ^ "ce/ 



"n(,g,+37'"n£.g;+38"-"t/ — U,U....U 



4.7.3 Interleaver for HS-SICH 

Interleaver for HS-SICH shall be done with the general method described in 4.2.1 1.1. 

4.7.4 Physical channel mapping for HS-SICH 

Physical channel mapping for HS-SICH shall be done with the general method described in 4.2.13. 
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